知識(shí)
不管是網(wǎng)站,軟件還是小程序,都要直接或間接能為您產(chǎn)生價(jià)值,我們?cè)谧非笃湟曈X表現(xiàn)的同時(shí),更側(cè)重于功能的便捷,營(yíng)銷的便利,運(yùn)營(yíng)的高效,讓網(wǎng)站成為營(yíng)銷工具,讓軟件能切實(shí)提升企業(yè)內(nèi)部管理水平和效率。優(yōu)秀的程序?yàn)楹笃谏?jí)提供便捷的支持!
您當(dāng)前位置>首頁(yè) » 新聞資訊 » 小程序相關(guān) >
微信小程序開發(fā)最佳實(shí)踐
發(fā)表時(shí)間:2021-3-31
發(fā)布人:葵宇科技
瀏覽次數(shù):69
weapp-starter
微信小程序開發(fā)最佳實(shí)踐
項(xiàng)目地址
為什么會(huì)有這個(gè) repo
在小程序之初便開發(fā)應(yīng)用了,現(xiàn)在小程序的開發(fā)也越來越成熟了,完善了很多的API、組件、架構(gòu)等,社區(qū)也由原來的零星點(diǎn)點(diǎn)到現(xiàn)在的不大不小,但也算是有了,期間也誕生了很多的開發(fā)框架,越來越多的三方輔助庫(kù),我也搗鼓出很多。比較有名的算是 wepy
和 labrador
, wepy
是 vue
風(fēng)格的小程序開發(fā)框架, labrador
則比較親和 React
,各有千秋,也各有深坑,而labrador
作者目前已經(jīng)停止更新了 TnT,作為React深度使用者的我來說是憂傷的,于是我搗鼓出 wn-cli
來用類 React
快速開發(fā)微信小程序,然而在這個(gè)過程中,想了很多,為什么需要開發(fā)框架呢?小程序本身在一開始就強(qiáng)調(diào)框架,且現(xiàn)在做的也不差,后來總結(jié)了下,無非是不熟悉小程序這套框架,但學(xué)習(xí)新的中間框架去開發(fā)小程序,這不是更加加大了熟悉成本嗎?且出了問題增加了處理的代價(jià)。
于是,我重新思考了下,最佳的微信小程序開發(fā)實(shí)踐應(yīng)該是無痛的,且舒服的,無痛的是指在小程序的飛速發(fā)展變更中,我們不用重復(fù)的浪費(fèi)學(xué)習(xí)第三方框架和原生框架。舒服的是指,我們能用上我們熟悉的流行工程流,如:less 預(yù)編譯、async/await 異步請(qǐng)求,redux數(shù)據(jù)管理等。
以上,便是這個(gè) repo 的意義與原因。
設(shè)計(jì)概要
[x] 優(yōu)化小程序
API
Promise
化異步接口- 突破請(qǐng)求數(shù)量限制(隊(duì)列)
- [x] 使用 async/await
[x] 接入
Redux
管理頁(yè)面數(shù)據(jù)流- 直接接入,添加可配置項(xiàng)
- 添加
saga
管理操作
[x] 樣式書寫采用
less
預(yù)編譯- 使用
Gulp
管理自動(dòng)編譯,持續(xù)集成
- 使用
[x]
wxs
管理工具庫(kù)- 數(shù)據(jù)的格式化操作,如時(shí)間格式化、金幣格式化等
[x] 按需加載,子頁(yè)面分包(除卻
tab
頁(yè)面的其他頁(yè)面)- 按功能模塊分包加載(推薦)
- 按
tab
分包
- ps: 小程序 原生分包
[x] 資源自動(dòng)化管理
- 上傳 CDN
Promise
化異步接口
由于微信的API中異步接口都是有三個(gè)回調(diào)函數(shù)的,分別是 success
, fail
, complete
,執(zhí)行時(shí)機(jī)同字面上意思( complete
一定會(huì)在接口的最后執(zhí)行)。于是 結(jié)合 Promise
,簡(jiǎn)單的描述如下:(以下為簡(jiǎn)版,具體的可以看源碼)
原生微信小程序API:
wx.request({
// ... 其他一些配置項(xiàng)
success: () => {},
fail: () => {},
complete: () => {}
});
添加 Promise
后:
new Promise((resolve, reject) => {
wx.request({
// ... 其他一些配置項(xiàng)
success: resolve,
fail: reject,
complete: resolve, // 這里暫取 resolve 來解決
});
});
Promise
化后,使用起來就簡(jiǎn)單了:
wx.request({ /* ...一些配置項(xiàng) */}).then(res => {
console.log(res)
}, err => {
console.error(err)
})
結(jié)合下面的 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
文件,幸運(yùn)的是這件事情在這個(gè)repo中的Gulp
任務(wù)中自動(dòng)處理了。
以上,便可以在微信小程序中使用 async/await
了。
樣式書寫采用 less
預(yù)編譯
為什么選擇 less
,因?yàn)楹?jiǎn)單方便,前端編譯,輕量級(jí)。
注意:由于小程序本身的限制,在書寫樣式的時(shí)候,不要使用 less
的嵌套功能!
- 添加less 變量庫(kù)等
// ...
.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')]
}))
// ...
- 重命名樣式文件,以便小程序識(shí)別
// ...
.pipe(rename((path) => {
path.extname = '.wxss';
}))
// ...
資源自動(dòng)化管理
- 目前接入阿里云,監(jiān)測(cè)
assert
文件夾,自動(dòng)上傳圖片資源 - 根據(jù)配置自動(dòng)生成 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;
}
項(xiàng)目地址
相關(guān)案例查看更多
相關(guān)閱讀
- 云南網(wǎng)站建設(shè)
- 云南小程序制作
- 網(wǎng)站建設(shè)報(bào)價(jià)
- .net網(wǎng)站
- 云南小程序開發(fā)公司推薦
- 汽車報(bào)廢回收管理系統(tǒng)
- 商標(biāo)注冊(cè)
- 網(wǎng)站建設(shè)服務(wù)
- 定制小程序開發(fā)
- 英文網(wǎng)站建設(shè)公司
- web
- vue開發(fā)小程序
- 做網(wǎng)站
- 云南微信小程序開發(fā)
- 云南小程序開發(fā)公司哪家好
- 微信小程序開發(fā)入門課程
- python開發(fā)小程序
- 云南網(wǎng)站建設(shè)開發(fā)
- 支付寶小程序被騙
- 小程序用戶登錄
- 百度小程序開發(fā)公司
- 海報(bào)插件
- Web開發(fā)框架
- 智慧農(nóng)貿(mào)市場(chǎng)
- 網(wǎng)絡(luò)公司
- 昆明做網(wǎng)站建設(shè)的公司排名
- 麗江小程序開發(fā)
- 企業(yè)網(wǎng)站
- 小程序被騙退款成功
- 北京小程序開發(fā)