原文连接:https://blog.csdn.net/weixin_...
接触微信小程序有一段时间的开发者或开发团队,我相信多多少少都会为本身搭建封装一些便于开发的框架/脚手架,尤为是一些作过Web开发的开发者,受到现现在Web主流开发框架如Angular,React,Vue等的核心思想的影响,对数据/状态管理、组件化、跨平台等都有较高的追求。前端
因此,从小程序出现到如今,已经陆陆续续出现了一些遵循了这些Web开发思想的小程序框架,比较突出的就是WePY,一个由腾讯团队推出的小程序组件化开发框架,主要的特色以下:vue
这些特性基本上是现今主流Web开发的标配了。由于我在开发Web应用的时候也常用Vue,因此在试用WePY的过程当中以为很是的熟悉好上手,它确实是一个值得使用、能够有效提升生产力的好框架。webpack
不过,今天的主角并非这个类Vue框架WePY,我想聊的是另一个基于Vue的框架:美团点评团队出品的小程序开发框架:mpvue。为何说WePY是一个“类Vue”的框架,而这个mpvue是“基于Vue”的框架呢?由于WePY是在代码开发风格上借鉴了Vue,自己和Vue没有什么关系;而这个mpvue是从整个Vue的核心代码上通过二次开发而造成的一个框架,至关因而给Vue自己赋能,增长了开发微信小程序的能力。web
使用mpvue开发小程序,你将在小程序技术体系的基础上获取到这样一些能力:vue-cli
它的目标是:在将来最理想的状态下,能够一套代码能够直接跑在多端:WEB、微信小程序、支付宝小程序、Native(借助weex)。不过因为各个端之间都存在一些比较明显的差别性,从产品的层面上讲,不建议这么作,这个框架的官方他们对它的指望的也只是开发和调试体验的一致。npm
经过官网提供的五分钟快速上手视频,能够发现它的开发过程和Vue保持高度一致,连使用的命令行工具也仍是原先开发Web应用时所用的vue-cli
:
`#建立一个小程序工程
vue init mpvue/mpvue-quickstart my-project`
编写模板代码的时候一般也主要是以HTML为主,好比咱们编写一个.vue组件时写了以下代码:
`<template>
<div class="counter-warp">小程序
<p>Vuex counter:{{ count }}</p> <p> <button @click="increment">+</button> <button @click="decrement">-</button> </p> <a href="/pages/index/index" class="home">去往首页</a>
</div>
</template>`
而mpvue会经过编译,将这个HTML模板转换成小程序的WXML代码:
`<template name="counter$39c97971">
<view class="_div data-v-72101980 counter-warp">微信小程序
<view class="_p data-v-72101980">Vuex counter:{{ count }}</view> <view class="_p data-v-72101980"> <button bindtap="handleProxy" data-eventid="{{'0'}}" data-comkey="{{$k}}" class="_button data-v-72101980">+</button> <button bindtap="handleProxy" data-eventid="{{'1'}}" data-comkey="{{$k}}" class="_button data-v-72101980">-</button> </view> <navigator url="/pages/index/index" class="_a data-v-72101980 home">去往首页</navigator>
</view>
</template>
`
这样,咱们就能够彻底用开发Web应用的方式去开发小程序了,这为咱们减小了一些思惟切换方面的成本。其实最重要的是:
Vue真的很好用啊!
另外,提供一个对原生微信小程序、mpvue、WePY这三种开发小程序方式的比较,感兴趣的朋友能够参考一下:微信
想学前端的小伙伴,能够关注+私信回复《资料》免费获取哦~
感谢您的阅读!喜欢的能够收藏转发哦~weex