欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

前端又又出新框架,這次沒有打包了(ofa.js)

freeflydom
2023年11月27日 11:35 本文熱度 640

最近,前端開發領域又迎來了一個新框架——ofa.js。它的獨特之處在于,不依賴于現有的 nodes/npm/webpack 前端開發工作流程。與jQuery類似,只需引用一個腳本,您就能像使用React/Vue/Angular一樣輕松地開發大型應用。

極易上手

如果您要開發簡單的項目,想要用一個漂亮的按鈕組件,例如 Ant Design 中的 Button組件,你需要學習Node.js、NPM和React等知識,才能開始使用該按鈕組件。對于非前端開發者或初學者來說,這將是一個漫長的過程。

如果使用基于ofa.js 開發的組件,就不需要這么復雜了;你只需要了解HTML的基礎知識(即使不看ofa.js的文檔),也可以輕松使用基于ofa.js開發的組件。以下是使用官方的 punch-logo 代碼示例:

<!-- 引入ofa.js到您的項目 -->

<script src="https://cdn.jsdelivr.net/gh/kirakiray/ofa.js/dist/ofa.min.js"></script>


<!-- 加載預先開發的punch-logo組件 -->

<l-m src="https://kirakiray.github.io/ofa-v4-docs/docs/publics/comps/punch-logo.html"></l-m>


<!-- 使用punch-logo組件 -->

<punch-logo style="margin:50px 0 0 100px;">

    <img src="https://kirakiray.github.io/ofa-v4-docs/docs/publics/logo.svg" logo height="90" />

    <h2>不加班了</h2>

    <p slot="fly">下班給我</p>

    <p slot="fly">遲點下班</p>

    <p slot="fly">周末加班</p>

</punch-logo>


你可以最直接拷貝上面的代碼,放到一個空白的html文件內運行試試;這使得ofa.js非常容易與傳統的Web開發技術棧相融合。

一步封裝組件

封裝組件同樣非常簡單,只需一個HTML文件即可實現。以下是一個官方封裝的開關(switch)組件示例:

<!-- my-switch.html -->

<template component>

  <style>

    .switch {

      position: relative;

      display: inline-block;

      width: 60px;

      height: 34px;

      background-color: #ccc;

      transition: background-color 0.4s;

      border-radius: 34px;

      cursor: pointer;

    }


    .slider {

      position: absolute;

      height: 26px;

      width: 26px;

      left: 4px;

      bottom: 4px;

      background-color: white;

      transition: transform 0.4s;

      border-radius: 50%;

    }


    .switch.checked {

      background-color: #2196f3;

    }


    .switch.checked .slider {

      transform: translateX(26px);

    }

  </style>

  <div class="switch" class:checked="checked" on:click="checked = !checked">

    <span class="slider"></span>

  </div>

  <script>

    export default {

      tag: "my-switch",

      data: {

        checked: true,

      },

    };

  </script>

</template>


在使用時,只需使用 l-m 組件引用它:

<script src="https://cdn.jsdelivr.net/gh/kirakiray/ofa.js/dist/ofa.min.js"></script>

<l-m src="./my-switch.html"></l-m>

<my-switch></my-switch>


示例可以在官方網站下方查看。由于無需打包流程,只需將文件上傳到靜態服務器即可發布,還可以進行跨域引用,這極大降低了組件共享的成本。

多種模板語法糖

ofa.js與Vue和Angular一樣提供了許多模板語法糖,主要包括:

  • 文本渲染

  • 屬性綁定/雙向綁定

  • 事件綁定

  • 條件渲染

  • 列表渲染

  • ...

具體案例可在官網向下滾動至“提供多樣便捷的模板語法”處查看。

天生的狀態同步高手

與其他框架不同,ofa.js 使用無感狀態同步。這意味著數據不需要通過函數操作,只需設置數據對象即可實現狀態同步。以下是一個共享黑夜模式的按鈕示例:

// is-dark.js

const isDark = $.stanz({

  value: false,

});


export default isDark;


<!-- my-button.html -->

<template component>

  <style>

    :host {

      display: block;

    }


    .container {

      display: inline-block;

      padding: 0.5em 1em;

      color: white;

      border-radius: 6px;

      background-color: blue;

      cursor: pointer;

      user-select: none;

    }

    .container.dark {

      background-color: red;

    }

  </style>

  <div class="container" class:dark="isDark.value">

    <slot></slot>

  </div>

  <script>

    import isDark from "./is-dark.js";

    export default {

      data: {

        isDark: {},

      },

      attached() {

        // 共享dark對象數據

        this.isDark = isDark;

      },

      detached() {

        // 清除內存記錄

        this.isDark = {};

      },

    };

  </script>

</template>


您可以跳轉到 狀態同步案例 以查看效果。

最簡單的表單操作

表單只需調用formData方法,就能生成自動同步數據的對象:

<form id="myForm">

  <input type="text" name="username" value="John Doe" />

  <div>

    sex:

    <label>

      man

      <input type="radio" name="sex" value="man" />

    </label>

    <label>

      woman

      <input type radio="radio" name="sex" value="woman" />

    </label>

  </div>

  <textarea name="message">Hello World!</textarea>

</form>

<br />

<div id="logger"></div>

<script>

  const data = $("#myForm").formData();


  $("#logger").text = data;

  data.watch(() => {

    $("#logger").text = data;

  });

</script>


您還可以輕松地反向設置表單數據:

<form id="myForm">

  <input type="text" name="username" value="John Doe" />

  <div>

    sex:

    <label>

      man

      <input type="radio" name="sex" value="man" />

    </label>

    <label>

      woman

      <input type="radio" name="sex" value="woman" />

    </label>

  </div>

  <textarea name="message">Hello World!</textarea>

</form>

<br />

<div id="logger"></div>

<script>

  const data = $("#myForm").formData();


  setTimeout(() => {

    // 反向設置數據

    data.username = "Yao";

    data.sex = "man";

    data.message = "ofa.js is good!";

  }, 1000);

</script>


制作自定義表單組件也沒有其他框架那么復雜,只需為組件定義valuename屬性即可。

具體效果可跳轉至formData API查看。

開發應用

您還可以使用ofa.js開發Web應用,然后直接引用已開發的應用到您的網頁上:

<!DOCTYPE html>

<html>

  <head>

    <meta charset="UTF-8" />

    <meta name="viewport" content="width=device-width, initial-scale=1.0" />

    <title>應用演示</title>

    <script src="https://cdn.jsdelivr.net/gh/kirakiray/ofa.js/dist/ofa.min.js"></script>

  </head>

  <body>

    <o-app src="https://xxxxx.com/app-config.mjs"> </o-app>

  </body>

</html>


具體效果可跳轉至使用o-app組件查看。

SCSR

官方提供了一種類似服務端渲染的解決方案,它不僅保證了用戶體驗,還使頁面在靜態狀態下可被搜索引擎爬取。官網采用了SCSR的方案。

SCSR的全稱是Static Client-Side Rendering,又稱為靜態客戶端渲染。它是CSR(Client-Side Rendering)的一種變種,在保留了CSR用戶體驗的基礎上,還能夠讓頁面在靜態狀態下被搜索引擎爬取。

您可以點擊SCSR方案以查看詳細信息。

代碼簡潔

當前版本4.3.29的 ofa.min.js 文件僅有52KB,經過gzip壓縮后僅有18KB。

其他

最近升級到了v4版本,目前可用的第三方庫還比較有限,但以后將逐漸增加。作者正在準備開發基于ofa.js的UI庫。

作者是一位中國開發者,快去給 ofa.js 加星吧!


作者:皮卡怪獸
鏈接:https://juejin.cn/post/7295576148364460071
來源:稀土掘金
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。



該文章在 2023/11/27 11:36:06 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved