頻繁調用 setData及 setData過程當中頁面跳閃css
組件化支持能力太弱(幾乎沒有)html
不能使用 less、scss 等預編譯器前端
request 併發次數限制vue
在這裏我經過對目前已開源的三種經常使用小程序框架作一個綜合對比, 還有一個叫nanchi的基於react的小程序轉譯框架,因爲沒來的及研究暫不作比較;node
騰訊團隊開源的一款類vue語法規範的小程序框架,借鑑了Vue的語法風格和功能特性,支持了Vue的諸多特徵,好比父子組件、組件之間的通訊、computed屬性計算、wathcer監聽器、props傳值、slot槽分發,還有不少高級的特徵支持:Mixin混合、攔截器等;WePY發佈的第一個版本是2016年12月份,也就是小程序剛剛推出的時候,到目前爲止,WePY已經發布了52個版本, 最新版本爲1.7.2;react
美團團隊開源的一款使用 Vue.js 開發微信小程序的前端框架。使用此框架,開發者將獲得完整的 Vue.js 開發體驗,同時爲 H5 和小程序提供了代碼複用的能力。mpvue在發佈後的幾天間得到2.7k的star,上升速度飛起,截至目前爲止已經有13.7k的star;git
京東凹凸實驗室開源的一款使用 React.js 開發微信小程序的前端框架。它採用與 React 一致的組件化思想,組件生命週期與 React 保持一致,同時支持使用 JSX 語法,讓代碼具備更豐富的表現力,使用 Taro 進行開發能夠得到和 React 一致的開發體驗。,同時由於使用了react的緣由因此除了能編譯h5, 小程序外還能夠編譯爲ReactNative;github
同爲vue規範的mpvue和wepy的生命週期和各類方法不盡相同vuex
wepy生命週期基本與原生小程序相同,再此基礎上糅合了一些vue的特性; 對於WePY中的methods屬性,由於與Vue中的使用習慣不一致,很是容易形成誤解,這裏須要特別強調一下:WePY中的methods屬性只能聲明頁面wxml標籤的bind、catch事件,不能聲明自定義方法,這與Vue中的用法是不一致的。 `import wepy from 'wepy';npm
export default class MyPage extends wepy.page { // export default class MyComponent extends wepy.component { customData = {} // 自定義數據
customFunction () {} //自定義方法
onLoad () {} // 在Page和Component共用的生命週期函數
onShow () {} // 只在Page中存在的頁面生命週期函數
config = {}; // 只在Page實例中存在的配置數據,對應於原生的page.json文件
data = {}; // 頁面所需數據均需在這裏聲明,可用於模板數據綁定
components = {}; // 聲明頁面中所引用的組件,或聲明組件中所引用的子組件
mixins = []; // 聲明頁面所引用的Mixin實例
computed = {}; // 聲明計算屬性(詳見後文介紹)
watch = {}; // 聲明數據watcher(詳見後文介紹)
methods = {}; // 聲明頁面wxml中標籤的事件處理函數。注意,此處只用於聲明頁面wxml中標籤的bind、catch事件,自定義方法需以自定義方法的方式聲明
events = {}; // 聲明組件之間的事件處理函數
複製代碼
}`
mpvue 除了 Vue 自己的生命週期外,還兼容了小程序生命週期,這部分生命週期鉤子的來源於微信小程序的 Page, 除特殊狀況外,不建議使用小程序的生命週期 鉤子。
在列表渲染上三者也分別有不一樣的應用方法
wepy當須要循環渲染WePY組件時(相似於經過wx:for循環渲染原生的wxml標籤),必須使用WePY定義的輔助標籤
mpvue使用v-for與vue一致,只是須要注意一點,嵌套列表渲染,必須指定不一樣的索引!
taro的列表循環用法基本與react相同,有一點須要注意,在 React 中,JSX 是會編譯成普通的 JS 的執行,每個 JSX 元素,其實會經過 createElement 函數建立成一個 JavaScript 對象(React Element),所以實際上你能夠這樣寫代碼 React 也是徹底能渲染的:
可是 Taro 中,JSX 會編譯成微信小程序模板字符串,所以你不能把 map 函數生成的模板當作一個數組來處理。當你須要這麼作時,應該先處理須要循環的數組,再用處理好的數組來調用 map 函數。例如上例應該寫成:
mpvue目前全支持小程序的事件處理器,引入了 Vue.js 的虛擬 DOM ,在前文模版中綁定的事件會被掛在到 vnode 上,同時 compiler 在 wxml 上綁定了小程序的事件,並作了相應的映射,因此你在真實點擊的時候經過 runtime 中 handleProxy 經過事件類型分發到 vnode 的事件上,同 Vue 在 WEB 的機制同樣,因此能夠作到無損支持。同時還順便支持了自定義事件和 $emit 機制
事件映射表,左側爲 WEB 事件,右側爲 小程序 對應事件
**click** : 'tap',<br>
**touchstart**: 'touchstart',<br>
**touchmove**: 'touchmove',<br>
**touchcancel**: 'touchcancel',<br>
**touchend**: 'touchend',<br>
**tap**: 'tap',<br>
**longtap**: 'longtap',<br>
**input**: 'input',<br>
**change**: 'change',<br>
**submit**: 'submit',<br>
**blur**: 'blur',<br>
**focus**: 'focus',<br>
**reset**: 'reset',<br>
**confirm**: 'confirm',<br>
**columnchange**: 'columnchange',<br>
**linechange**: 'linechange',<br>
**error**: 'error',<br>
**scrolltoupper**: 'scrolltoupper',<br>
**scrolltolower**: 'scrolltolower',<br>
**scroll**: 'scroll'<br>
複製代碼
踩坑注意(官方文檔):
wepy事件綁定區別於vue,根據原生小程序事件提供了語法優化
綁定事件
bindtap="click" 替換爲 @tap="click",
取消冒泡
原catchtap="click"替換爲@tap.stop="click"。
捕獲監聽事件
capture-bind:tap="click" 替換爲 @tap.capture="click",
中斷捕獲監聽
capture-catch:tap=「click"替換爲 @tap.capture.stop="click"。
Taro 元素的事件處理和 DOM 元素的很類似。可是有一點語法上的不一樣:
Taro 事件綁定屬性的命名採用駝峯式寫法,而不是小寫。 若是採用 JSX 的語法你須要傳入一個函數做爲事件處理函數,而不是一個字符串 (DOM 元素的寫法)。 例如,傳統的微信小程序模板:
Taro 中稍稍有點不一樣:
在 Taro 中另外一個不一樣是你不能使用 catchEvent 的方式阻止事件冒泡。你必須明確的使用 stopPropagation。例如,阻止事件冒泡你能夠這樣寫:
wepy對wx.request作了接受參數的修改,值得一提的是它提供了針對全局的intercapter攔截器
攔截器
taro對request進行了二次封裝,可使用Taro.request(OBJECT)發起網絡請求,支持 Promise 化使用。
mpvue沒有對request作特殊優化,與原生相同,能夠本身根據須要進行封裝如何選擇適合本身的項目