摘要:于是,我重新思考了下,最佳的微信小程序開發(fā)實踐應該是無痛的,且舒服的,無痛的是指在小程序的飛速發(fā)展變更中,我們不用重復的浪費學習第三方框架和原生框架。以上,便可以在微信小程序中使用了。
weapp-starter
微信小程序開發(fā)最佳實踐
項目地址
為什么會有這個 repo在小程序之初便開發(fā)應用了,現(xiàn)在小程序的開發(fā)也越來越成熟了,完善了很多的API、組件、架構等,社區(qū)也由原來的零星點點到現(xiàn)在的不大不小,但也算是有了,期間也誕生了很多的開發(fā)框架,越來越多的三方輔助庫,我也搗鼓出很多。比較有名的算是 wepy 和 labrador,wepy 是 vue 風格的小程序開發(fā)框架,labrador 則比較親和 React,各有千秋,也各有深坑,而 labrador 作者目前已經停止更新了 TnT,作為React深度使用者的我來說是憂傷的,于是我搗鼓出 wn-cli 來用類 React 快速開發(fā)微信小程序,然而在這個過程中,想了很多,為什么需要開發(fā)框架呢?小程序本身在一開始就強調框架,且現(xiàn)在做的也不差,后來總結了下,無非是不熟悉小程序這套框架,但學習新的中間框架去開發(fā)小程序,這不是更加加大了熟悉成本嗎?且出了問題增加了處理的代價。
于是,我重新思考了下,最佳的微信小程序開發(fā)實踐應該是無痛的,且舒服的,無痛的是指在小程序的飛速發(fā)展變更中,我們不用重復的浪費學習第三方框架和原生框架。舒服的是指,我們能用上我們熟悉的流行工程流,如:less 預編譯、async/await 異步請求,redux數(shù)據管理等。
以上,便是這個 repo 的意義與原因。
設計概要
[x] 優(yōu)化小程序 API
Promise 化異步接口
突破請求數(shù)量限制(隊列)
[x] 使用 async/await
[x] 接入 Redux 管理頁面數(shù)據流
直接接入,添加可配置項
添加 saga 管理操作
[x] 樣式書寫采用 less 預編譯
使用 Gulp 管理自動編譯,持續(xù)集成
[x] wxs 管理工具庫
數(shù)據的格式化操作,如時間格式化、金幣格式化等
[x] 按需加載,子頁面分包(除卻 tab 頁面的其他頁面)
按功能模塊分包加載(推薦)
按 tab 分包
ps: 小程序原生分包
[x] 資源自動化管理
上傳 CDN
Promise 化異步接口由于微信的API中異步接口都是有三個回調函數(shù)的,分別是success,fail,complete,執(zhí)行時機同字面上意思(complete一定會在接口的最后執(zhí)行)。于是 結合Promise,簡單的描述如下:(以下為簡版,具體的可以看源碼)
原生微信小程序API:
wx.request({ // ... 其他一些配置項 success: () => {}, fail: () => {}, complete: () => {} });
添加Promise后:
new Promise((resolve, reject) => { wx.request({ // ... 其他一些配置項 success: resolve, fail: reject, complete: resolve, // 這里暫取 resolve 來解決 }); });
Promise 化后,使用起來就簡單了:
wx.request({ /* ...一些配置項 */}).then(res => { console.log(res) }, err => { console.error(err) })
結合下面的 async/await 就可以更加方便的書寫同步代碼
使用 async/await添加 babel:
yarn add babel-core
安裝 env presets
yarn add babel-preset-env
使用 .babelrc
{ "presets": [ "env" ] }
在 Gulp 中使用 babel
// install yarn add gulp-babel const babel = require("gulp-babel"); // ... .pipe(babel()) // ...
添加 runtime,在使用async/await的地方引入 ./src/utils/lib/runtime.js 文件,幸運的是這件事情在這個repo中的Gulp任務中自動處理了。
以上,便可以在微信小程序中使用 async/await了。
樣式書寫采用 less 預編譯為什么選擇 less,因為簡單方便,前端編譯,輕量級。
注意:由于小程序本身的限制,在書寫樣式的時候,不要使用 less 的嵌套功能!
添加less 變量庫等
// ... .pipe(addLessImport({ themePath: path.join(__dirname, "./src/theme/index.less"), commomPath: path.join(__dirname, "./src/app.less"), })) // ...
編譯
// ... .pipe(less({ paths: [path.join(__dirname, "./src/theme")] })) // ...
重命名樣式文件,以便小程序識別
// ... .pipe(rename((path) => { path.extname = ".wxss"; })) // ...資源自動化管理
目前接入阿里云,監(jiān)測 assert 文件夾,自動上傳圖片資源
根據配置自動生成 less 配置 config.less
gulp.src("src/theme/config.less", { allowEmpty: true }) .pipe(file("config.less", `@cdn: ~"${config.cdn}";`)) .pipe(changed("src/theme")) .pipe(gulp.dest("src/theme"))
使用
page { background-image: url("@{cdn}/index-bg.png"); background-attachment: fixed; }
項目地址
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/92702.html
摘要:多端統(tǒng)一開發(fā)框架優(yōu)秀學習資源匯總官方資源項目倉庫官方文檔項目倉庫官方文檔微信小程序官方文檔百度智能小程序官方文檔支付寶小程序官方文檔字節(jié)跳動小程序官方文檔文章教程不敢閱讀包源碼帶你揭秘背后的哲學從到構建適配不同端微信小程序等的應用小程序最 Awesome Taro 多端統(tǒng)一開發(fā)框架 Taro 優(yōu)秀學習資源匯總 showImg(https://segmentfault.com/img/r...
摘要:微信小程序應用號開發(fā)資源匯總文檔工具教程代碼插件組件文檔從搭建一個微信小程序開始小程序開發(fā)文檔小程序設計指南工具小程序開發(fā)者工具官方支持微信小程序實時預覽的支持的微信小程序組件化開發(fā)框架轉在線工具小程序云端增強社區(qū)微信小程序 微信(小程序or應用號)開發(fā)資源匯總-文檔-工具-教程-代碼-插件-組件 文檔 從搭建一個微信小程序開始 小程序開發(fā)文檔 小程序設計指南 工具 小程序開發(fā)者...
閱讀 2132·2023-04-25 14:56
閱讀 2465·2021-11-16 11:44
閱讀 2701·2021-09-22 15:00
閱讀 1907·2019-08-29 16:55
閱讀 2185·2019-08-29 14:04
閱讀 2312·2019-08-29 11:23
閱讀 3685·2019-08-26 10:46
閱讀 1913·2019-08-22 18:43