Okam(奧卡姆):小程式開發框架,支持百度小程式、微信小程式、支付寶小程式

来源:https://www.cnblogs.com/xiao-hong/archive/2018/11/10/9937780.html
-Advertisement-
Play Games

Okam(奧卡姆):小程式開發框架,支持百度小程式、微信小程式、支付寶小程式 ...


Okam(奧卡姆):小程式開發框架

Okam 是什麼

`Okam` 一個面向小程式開發的開發框架,開發體驗類 `Vue`。詳情

Okam 對各小程式的支持情況

  • 支持 百度小程式
  • 支持 微信小程式
  • 支持 支付寶小程式

Okam 提供了什麼

  • 開發模式
    • 支持單文件組件化開發方式,目錄結構更加清晰簡潔
    • 支持 NPM 包的依賴管理和引用
    • 提供漸進增強可配置方式,包括可配置的構建流程,來提升開發框架能力
  • 開發語法
    • 模板:支持類 `Vue` 模板語法、`Pug` 模板語法
    • 樣式:支持 CSS 預處理器和後處理器, `Stylus`、`Less`、`Sass`、`Postcss`
    • 腳本:支持 `Typescript`、`ES Next` 語法支持
  • 擴展的能力
    • `HTML` 標簽支持
    • Vue` 數據操作語法,包括 `computed`、`watch` 支持
    • `Redux` 數據狀態管理
    • 模板組件 `ref` 引用支持
    • `Mixins` 支持
    • `Promise`、`Async`、`await` 語法支持
    • 原生介面支持可定製的 `Promise` 化
    • 提供原生介面 `Hook` 能力
    • 樣式 `rpx` 單位自動轉換
    • 介面 `Mock`
    • 圖片自動壓縮能力
  • 其它
    • 框架 `API` 優化及擴展、數據操作優化
    • 微信請求優化
    • 原生小程式和開發框架語法混用支持

代碼示例

  • 入口腳本
 1 /**
 2 * @file 小程式入口
 3 * @author <author>
 4 */
 5  
 6 'use strict';
 7  
 8 export default {
 9     config: {
10         pages: [
11             'pages/home/index'
12         ],
13          
14         window: {
15             navigationBarBackgroundColor: '#211E2E',
16             navigationBarTextStyle: 'white',
17             backgroundTextStyle: 'light',
18             enablePullDownRefresh: true,
19             backgroundColor: '#ccc'
20         },
21          
22         networkTimeout: {
23             request: 30000
24         }
25     },
26      
27     $promisifyApis: []
28 };
View Code
  • 入口樣式
1 /**
2 * @file The app entry style
3 * @author <author>
4 */
5  
6 @require './common/css/mixin.styl'
7 @require './common/css/variable.styl'
8 @require './common/css/common.styl'
View Code
  • 頁面
 1 <template>
 2 <view class="home-wrap">
 3     <hello :from="from" @hello="handleHello"></hello>
 4     <view class="click-tip" if="clicked">You click me~</view>
 5 </view>
 6 </template>
 7 <script>
 8 import Hello from '../../components/Hello';
 9  
10 export default {
11     config: {
12         title: 'Page Title'
13     },
14      
15     components: {
16         Hello
17     },
18      
19     data: {
20         btnText: 'Hello',
21         clicked: false,
22         from: 'HomePage'
23     },
24      
25     methods: {
26      
27         handleHello(e) {
28             this.clicked = true;
29             this.btnText = 'You clicked';
30              
31             this.$api.showToast({
32                 title: 'Received Hello',
33                 duration: 3000
34             });
35         }
36     }
37 };
38 </script>
39 <style lang="stylus">
40 @require '../../common/css/variable.styl'
41 @require '../../common/css/mixin.styl'
42  
43 .home-wrap
44     padding: 100px
45     height: 100vh
46     box-sizing: border-box
47     background: #ddd
48  
49 .click-tip
50     margin-top: 100px
51     padding: 20px
52     text-align: center
53     color: red
54  
55 </style>
View Code
  • 組件
 1 <template>
 2 <view class="hello-wrap">
 3 <button plain class="hello-btn" @click="handleClick">Hello in {{from}}</button>
 4 </view>
 5 </template>
 6 <script>
 7 export default {
 8     config: {
 9     },
10      
11     props: {
12         from: String
13     },
14      
15     components: {
16     },
17      
18     data: {
19     },
20      
21     methods: {
22         handleClick() {
23             this.$emit('hello', {from: this.from});
24         }
25     }
26 };
27 </script>
28 <style lang="stylus">
29 .hello-wrap
30     padding: 20px
31     margin: 20px 0
32  
33 .hello-btn
34     width: 846px
35     height: 148px
36     margin: 0 auto
37     line-height: @height
38     background: #fff
39     text-align: center
40     border-radius: 120px
41     border: none
42 </style>
View Code

 

 

完整示例詳見

操作步驟:

git clone https://github.com/ecomfe/okam-template.git
 
cd okam-template
 
npm i
 
npm run dev // 百度小程式開發模式
 
npm run dev:wx // 微信小程式開發模式
 
開發工具 打開 構建產物目錄 `dist、wx_dist`

更多詳細信息

技術交流

技術交流:QQ 群:`728460911`,入群備註:okam

技術學習:項目代碼開源在 Github 上,有問題或者建議,歡迎提 issue, 發 pr


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 什麼是事務 事務是現代資料庫的核心概念之一,它表示資料庫一系列操作的集合。這些操作必須在一個事務當中,要麼全部執行成功,要麼全部不執行。 ACID原則 原子性(Atomicity) 原子性是指事務包含的所有操作要麼全部成功,要麼全部失敗回滾,因此事務的操作如果成功就必須要完全應用到資料庫,如果操作失 ...
  • 歡迎大家前往 "騰訊雲+社區" ,獲取更多騰訊海量技術實踐乾貨哦~ 本文由 "騰訊雲資料庫 TencentDB" 發表於 "雲+社區專欄" 今天我分享的主題內容大概是兩部分,最主要的還是小游戲和小程式,第一部分就是跟大家分享下我們在現網運營中服務小游戲以及爆款小游戲積累的經驗。在現網運維中我們做了一 ...
  • 作者:天山老妖S 鏈接:http://blog.51cto.com/9291927 一、事務簡介 1、事務簡介 事務(Transaction)是指作為單個邏輯工作單元執行的一系列操作。 2、事物的特效 A、原則性(Atomicity) 表示組成一個事物的多個資料庫操作是一個不可分隔的原子單元,只有所 ...
  • 分散式事務創建註意事項 指定一個由 Transact-SQL 分散式事務處理協調器 (MS DTC) 管理的 Microsoft 分散式事務的起點。 執行 BEGIN DISTRIBUTED TRANSACTION 語句的 SQL Server 資料庫引擎的實例是事務創建者,並控制事務的完成。 當為 ...
  • 歡迎大家前往 "騰訊雲+社區" ,獲取更多騰訊海量技術實踐乾貨哦~ 本文由 "goo" 發表於 "雲+社區專欄" 與生活緊密相連的音視頻,為何有那麼多格式?直播、點播以及即時視頻其中又有怎樣的機制支撐?面對紛繁複雜的音視頻知識,應該如何學起?快速探索,音視頻技術不再神秘。 前言 面對一門技術,我們熟 ...
  • Error:Execution failed for task ':app:transformDexArchiveWithExternalLibsDexMergerForDebug'.> java.lang.RuntimeException: java.lang.RuntimeException: ...
  • 譯文開始 函數式編程是一種編程風格,這種編程風格就是試圖將傳遞函數作為參數(即將作為回調函數)和返回一個函數,但沒有函數副作用(函數副作用即會改變程式的狀態)。 有很多語言採用這種編程風格,其中包括JavaScript、Haskell、Clojure、Erlang和Scala等一些很流行的編程語言。 ...
  • 內容:表單標簽插入組件(經常使用)############################################################## 如果這些值需要提交到服務端的,每個組件的屬性都需要name######################################### ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...