专栏名称: SegmentFault思否
SegmentFault (www.sf.gg)开发者社区,是中国年轻开发者喜爱的极客社区,我们为开发者提供最纯粹的技术交流和分享平台。
目录
相关文章推荐
程序员的那些事  ·  GPU:DeepSeek ... ·  11 小时前  
OSC开源社区  ·  2024: 大模型背景下知识图谱的理性回归 ·  4 天前  
OSC开源社区  ·  升级到Svelte ... ·  5 天前  
程序员的那些事  ·  惊!小偷“零元购”后竟向 DeepSeek ... ·  4 天前  
程序员小灰  ·  DeepSeek做AI代写,彻底爆了! ·  5 天前  
51好读  ›  专栏  ›  SegmentFault思否

微信小程序开发最佳实践

SegmentFault思否  · 公众号  · 程序员  · 2018-02-02 08:00

正文

项目地址:https://github.com/skyFi/weapp-starter

为什么会有这个 repo

在小程序之初便开发应用了,现在小程序的开发也越来越成熟了,完善了很多的API、组件、架构等,社区也由原来的零星点点到现在的不大不小,但也算是有了,期间也诞生了很多的开发框架,越来越多的三方辅助库,我也捣鼓出很多。比较有名的算是 wepy labrador wepy vue 风格的小程序开发框架, labrador 则比较亲和 React ,各有千秋,也各有深坑,而 labrador 作者目前已经停止更新了 TnT,作为React深度使用者的我来说是忧伤的,于是我捣鼓出 wn-cli 来用类 React 快速开发微信小程序,然而在这个过程中,想了很多,为什么需要开发框架呢?小程序本身在一开始就强调框架,且现在做的也不差,后来总结了下,无非是不熟悉小程序这套框架,但学习新的中间框架去开发小程序,这不是更加加大了熟悉成本吗?且出了问题增加了处理的代价。

于是,我重新思考了下,最佳的微信小程序开发实践应该是无痛的,且舒服的,无痛的是指在小程序的飞速发展变更中,我们不用重复的浪费学习第三方框架和原生框架。舒服的是指,我们能用上我们熟悉的流行工程流,如:less 预编译、async/await 异步请求,redux数据管理等。

以上,便是这个 repo 的意义与原因。

设计概要

  • [x] 优化小程序 API

  1. Promise 化异步接口

  2. 突破请求数量限制(队列)

  • [x] 使用 async/await

  • [x] 接入 Redux 管理页面数据流

    1. 直接接入,添加可配置项

    2. 添加 saga 管理操作

  • [x] 样式书写采用 less 预编译

    1. 使用 Gulp 管理自动编译,持续集成

  • [x] wxs 管理工具库

    1. 数据的格式化操作,如时间格式化、金币格式化等

  • [x] 按需加载,子页面分包(除却 tab 页面的其他页面)

    1. 按功能模块分包加载(推荐)

    2. tab 分包

  • [x] 资源自动化管理

    1. 上传 CDN

    Promise 化异步接口

    由于微信的API中异步接口都是有三个回调函数的,分别是 success fail complete ,执行时机同字面上意思( complete 一定会在接口的最后执行)。于是结合 Promise ,简单的描述如下(以下为简版,具体的可以看源码)。

    原生微信小程序API:

    1. wx.request({

    2.  // ... 其他一些配置项

    3.  success: () => {},

    4.  fail: () => {},

    5.  complete: () => {}

    6. });

    添加 Promise 后:

    1. new Promise((resolve, reject) => {

    2.  wx.request({

    3.    // ... 其他一些配置项

    4.    success: resolve,

    5.    fail: reject,

    6.    complete: resolve, // 这里暂取 resolve 来解决

    7.  });

    8. });

    Promise 化后,使用起来就简单了:

    1. wx.request({ /* ...一些配置项 */}).then(res => {

    2.  console.log(res)

    3. }, err => {

    4.  console.error(err)

    5. })

    结合下面的 async/await 就可以更加方便的书写同步代码。

    使用 async/await

    1.添加 babel

    1. yarn add babel-core

    2.安装 env presets

    1. yarn add babel-preset-env

    3.使用 .babelrc

    1. {

    2.  "presets": [

    3.    "env"

    4.  ]

    5. }

    4.在 Gulp 中使用 babel

    1. // install

    2. yarn add gulp-babel

    3. const babel = require('gulp-babel');

    4. // ...

    5. .pipe(babel())

    6. // ...

    5.添加 runtime ,在使用 async/await 的地方引入 ./src/utils/lib/runtime.js 文件,幸运的是这件事情在这个repo中的 Gulp 任务中自动处理了。

    以上,便可以在微信小程序中使用 async/await 了。

    样式书写采用 less 预编译

    为什么选择 less ,因为简单方便,前端编译,轻量级。

    注意:由于小程序本身的限制,在书写样式的时候,不要使用 less 的嵌套功能!

    1.添加 less 变量库等

    1. // ...

    2. .pipe(addLessImport({

    3.      themePath: path.join(__dirname, './src/theme/index.less'),

    4.      commomPath: path.join(__dirname, './src/app.less'),

    5.    }))

    6. // ...

    2.编译

    1. // ...

    2. .pipe(less({

    3.      paths: [path.join(__dirname,







    请到「今天看啥」查看全文