基于gulp的快速构建微信小程序的脚手架
- 实现Vue框架的computed和watch方法,开发更便捷
- 实现Vue框架的mixins功能,更方便公共方法和公共逻辑的复用
- sass编写样式,替代wxss
- webfont自动base64转换,解决了微信小程序无法引用本地字体的问题
- 采用es6语法开发,babel编译
- 图片压缩
- 区分开发生产两套环境,支持生产环境打包
- 本地数据mock功能
# 启动开发服务
$ npm start
# 构建产出
$ npm run build
# 清空产出dist文件夹
$ npm run clean
# 云开发 · 启动云开发服务(监视云开发相关文件变化)
$ npm run cloud
# 启动mock服务器
$ npm run server
├── client // 小程序 client 部分,主要编写内容
│ ├── app.js
│ ├── app.json
│ ├── app.scss
│ ├── project.config.json // 小程序项目配置
│ ├── components // 自定义组件
│ ├── images // 图片资源
│ ├── lib
| │ ├──regenerator-runtime // async await 解决方案,在需要的文件内引入runtime-module.js即可
│ │ │ ├── runtime.js
│ │ │ ├── runtime-module.js
│ │ │ ├── path.js
│ │ │ ├── README.md
│ │ │ └── package.json
│ │ ├── api-mock.js // api-mock 功能
│ │ ├── api.js // 实际 api
│ │ ├── initPage.js // 页面初始化方法,实现了vue的mixins功能
│ │ ├── vuefy.js // 实现vue的 computed 和 watch 功能
│ │ └── util.js
│ └── pages
│ └── index
├── server // 小程序 server 部分,主要是静态资源和云函数
│ ├── cloud-functions
│ │ ├── test
│ │ └── test2
│ ├── index.js
│ ├── inline // 云函数公共模块,打包的时候会 inline 进引入的云函数
│ │ └── utils.js
│ └── static
│ └── gulp.png
├── test // 测试文件夹
│ └── functions // 存储小程序云测试用的参数模板
│ └── test.json
├── config.server.json
├── dist // 产出文件夹,通过微信开发者工具打开预览效果
├── gulpfile.js
├── package.json
├── README.md
├── .babelrc
├── .editorconfig
├── .eslintignore
├── .eslintrc
└── .gitignore
client: 小程序客户端相关代码 server: mock服务器相关逻辑及云函数
// 利用jsdists实现开发环境和发布环境不同的打包规则
// 以下只在开发环境中起效果
/* <remove trigger="prod"> */
import {
test
} from '../../lib/api-mock';
/* </remove> */
// 以下只在prod环境中起效果
/* <jdists trigger="prod">
import { test } from '../../lib/api';
</jdists> */
config.server.json: mock服务器相关配置 client/lib/regenerator-runtime.js: async await 方案, 在需要用到async await的文件内引入
import regeneratorRuntime from '../../lib/regenerator-runtime/runtime-module';