微信小程序WePY框架是腾讯官方推出来的框架,相似的框架还有美团的mpvue,京东的Taro等; 目前公司开发小程序主要用到的是微信原生方法和官方的wepy框架; wepy框架在开发过程当中参考了 Vue 等现有框架的一些语法风格和功能特性,对原生小程序的开发模式进行了再次封装,更贴近于 MVVM 架构模式, 并支持ES6/7的一些新特性。相对更容易上手,提升开发效率;html
npm install wepy-cli -g
wepy new myproject
cd myproject
npm install
wepy build --watch
WePY项目的目录结构以下vue
├── dist 小程序运行代码目录(该目录由WePY的build指令自动编译生成,请不要直接修改该目录下的文件) ├── node_modules ├── src 代码编写的目录(该目录为使用WePY后的开发目录) | ├── components WePY组件目录(组件不属于完整页面,仅供完整页面或其余组件引用) | | ├── com_a.wpy 可复用的WePY组件a | | └── com_b.wpy 可复用的WePY组件b | ├── pages WePY页面目录(属于完整页面) | | ├── index.wpy index页面(经build后,会在dist目录下的pages目录生成index.js、index.json、index.wxml和index.wxss文件) | | └── other.wpy other页面(经build后,会在dist目录下的pages目录生成other.js、other.json、other.wxml和other.wxss文件) | └── app.wpy 小程序配置项(全局数据、样式、声明钩子等;经build后,会在dist目录下生成app.js、app.json和app.wxss文件) └ ── package.json 项目的package配置
1). wepy和vue列表循环对比: // wepy 列表循环,外面可套一层repeat标签,注意和vue写法的区别 <repeat for="{{list}}" key="index> <view>{{item}}</view> </repeat> // vue 列表循环,外面可套一层template标签 <template v-for="(item,index) in list" :key="index"> // 不推荐key直接用索引index <div>{{item}}<div> </template> 2). wepy和vue条件渲染中,wepy须要加{{}},vue不须要,里面均可以写表达式进行判断: <view wx:if="{{show}}"></view> <div v-if="show"></div> 3). 父子组件值传递二者都在子组件中用props接收, props中能够定义能接收的数据类型,若是不符合会报错, wepy能够经过使用.sync修饰符来达到父组件数据绑定至子组件的效果,也能够经过设置子组件props的 twoWay:true来达到子组件数据绑定至父组件的效果。那若是既使用.sync修饰符,同时子组件props中 添加的twoWay: true时,就能够实现数据的双向绑定了; // parent.wpy <child :title="parentTitle" :syncTitle.sync="parentTitle" :twoWayTitle="parentTitle"></child> data = { parentTitle: 'p-title' }; // child.wpy props = { // 静态传值 title: String, // 父向子单向动态传值 syncTitle: { type: String, default: 'null' }, twoWayTitle: { type: String, default: 'nothing', twoWay: true } }; onLoad () { console.log(this.title); // p-title console.log(this.syncTitle); // p-title console.log(this.twoWayTitle); // p-title this.title = 'c-title'; console.log(this.$parent.parentTitle); // p-title. this.twoWayTitle = 'two-way-title'; this.$apply(); console.log(this.$parent.parentTitle); // two-way-title. --- twoWay为true时,子组件props中的属性值改变时,会同时改变父组件对应的值 this.$parent.parentTitle = 'p-title-changed'; this.$parent.$apply(); console.log(this.title); // 'c-title'; console.log(this.syncTitle); // 'p-title-changed' --- 有.sync修饰符的props属性值,当在父组件中改变时,会同时改变子组件对应的值。
2.wepy支持自定义组件开发,实现组件复用,减小代码冗余,提升开发效率;node
3.wepy支持引入npm包,拓展了不少方法; git
4.支持Promise,ES2015+特性,如async await 等;github
5.支持多种编译器,Less/Sass/Styus、Babel/Typescript、Pug;npm
6.支持多种插件处理,文件压缩,图片压缩,内容替换等; json
7.支持 Sourcemap,ESLint代码规范管理等; 小程序
8.对小程序wx.request方法参数进行了修改,返回Promise对象,优化了事件参数传递,具体用法以下:微信小程序
// wx.request原生代码: wx.request({ url: 'xxx', success: function (data) { console.log(data); } }); // WePY 使用方式, 须要开启 Promise 支持,参考开发规范章节 wepy.request('xxxx').then((d) => console.log(d)); // async/await 的使用方式, 须要开启 Promise 和 async/await 支持,参考 WIKI async function request () { let d = await wepy.request('xxxxx'); console.log(d); // 原生的事件传参方式: <view data-id="{{index}}" data-title="wepy" data-other="otherparams" bindtap="tapName"> Click me! </view> Page({ tapName: function (event) { console.log(event.currentTarget.dataset.id)// output: 1 console.log(event.currentTarget.dataset.title)// output: wepy console.log(event.currentTarget.dataset.other)// output: otherparams } }); // WePY 1.1.8之后的版本,只容许传string。 <view @tap="tapName({{index}}, 'wepy', 'otherparams')"> Click me! </view> methods: { tapName (id, title, other, event) { console.log(id, title, other)// output: 1, wepy, otherparams } }
本文总结的比较浅显,不少地方说的也不是太详细,欢迎你们留言一块儿交流探讨,坚持学习,不断探索总结,路漫漫其修远兮,吾将上下而求索!
参考资料:wepy官方文档 ; 微信小程序官网开发文档 ; vue官方开发文档微信