小程序開發框架的目標是經過儘量簡單、高效的方式讓開發者能夠在微信中開發具備原生 APP 體驗的服務。html
微信團隊爲小程序提供的框架命名爲MINA。MINA框架經過封裝微信客戶端提供的文件系統、網絡通訊、任務管理、數據安全等基礎功能,對上層提供一整套JavaScript API,讓開發者方便的使用微信客戶端提供的各類基礎功能與能力,快速構建應用。ios
微信小程序的框架示意圖以下所示:json
第一部分頁面視圖層,開發者使用WXML文件來搭建頁面的基本視圖結構(WXML是相似於HTML標籤的語言和一系列基礎組件),使用WXSS文件來控制頁面的表現樣式。小程序
第二部分AppService應用邏輯層,是MINA框架的服務中心,經過微信客戶端啓動異步線程單獨加載運行,頁面渲染所需的數據、頁面交互處理邏輯都在其中實現。MINA框架中的AppService使用JavaScript來編寫交互邏輯、網絡請求、數據處理,但不能使用JavaScript中的DOM操做。小程序中的各個頁面能夠經過AppService實現數據管理、網絡通訊、生命週期管理和頁面路由。微信小程序
MINA框架爲頁面組件提供了一系列事件監聽相關的屬性(好比bindtap、bindtouchstart等),來與AppService中的事件處理函數綁定在一塊兒,來實現頁面向AppService層同步用戶交互數據。MINA框架同時提供了不少方法將AppService中的數據與頁面進行單向綁定(注意數據的綁定方向是單向的),當AppService中的數據變動時,會主動觸發對應頁面組件的從新渲染。瀏覽器
框架的核心是一個響應式的數據綁定系統,它能讓數據與視圖很簡單的保持同步。只須要在邏輯層修改數據,視圖層就會作相應的更新。示例以下:緩存
<!--頁面視圖層代碼--> <view class="apptitle"> <text class="app-avatar">歡迎使用{{appname}}</text> <button bindtap="changeAppname">更換名稱 </button> </view> //AppService應用邏輯層代碼 //初始數據 page({ data:{ appname:'易投票' }, changeAppname:function(e){ this.setData({ appname:'個人小程序' }) } })
圖1:初始名稱 圖2:點擊按鈕「更換名稱」之後安全
示例中數據是如何更新的呢?首先,開發者經過框架將AppService應用邏輯層數據中的appname與頁面視圖層名爲appname的變動進行了綁定,頁面在剛打開的時候會顯示「歡迎使用 易投票。而後,當點擊按鈕「更換名稱」以後,視圖層會發送changeAppname的tap事件給邏輯層,邏輯層找到事件函數changeAppname。最後,邏輯層changeAppname函數執行了setData操做,將對象appname的值改變爲「個人小程序」,由於該對象已經在視圖層綁定,因此視圖層會顯示爲圖2的名稱了。微信
小程序的MINA框架有着接近原生App的運行速度,在框架層面作了大量的優化,在重功能上(page或tab切換、多媒體、網絡鏈接等)上使用接近於native的組件繼承,對安卓和ios端作出了高度一致的呈現,還有近乎完備的開發、調試工具。網絡
典型的小程序目錄結構很是簡潔,通常一個項目包含兩個目錄(pages和utils)三個文件(app.js、app.json、app.wxss)。pages目錄下包括程序所需的各個頁面,一個頁面對應一個目錄,包含2至4個文件(.js、.wxml、.json及.wxss)。utils目錄則包含一些公共的js代碼文件。固然,咱們還能夠添加其餘的公共目錄,如用來存放本地圖片資源的images目錄。
小程序的邏輯層就是全部.js腳本文件的集合。小程序在邏輯層處理數據併發送至視圖層,同時接受視圖層發回的事件請求。
MINA框架的邏輯層是由JavaScript編寫,在此基礎上,微信團隊作出了一些優化,以便更高效的開發小程序,這些優化包括:
一、增長app方法用來註冊程序,增長page方法用來註冊頁面;
二、提供豐富的API接口;
三、頁面的做用域相對獨立,並擁有了模塊化的能力;
簡單歸納,邏輯層就是各個頁面的.js腳本文件。
須要注意的是,小程序的邏輯層由js編寫,但並非在瀏覽器中運行的,因此JavaScript在Web中的一些能力都不能使用,好比 dom、window等,這也是咱們開發過程當中要克服的阻礙。
對於微信小程序而言,視圖層就是全部的.wxml(WeiXin Markup language)文件與.wxss(WeiXin Style Sheet)文件的集合:.wxml用於描述頁面結構而.wxss用於描述頁面樣式。
視圖層以給定的樣式來展示數據並反饋事件給邏輯層,而數據展示是以組件來進行的。組件(Component)是視圖的基本組成單元。
數據層包括臨時數據或緩存、文件存儲、網絡存儲與調用。
在頁面page()中,咱們要使用setData函數來將數據從邏輯層發送到視圖層,同時改變對應的this.data的值。this在小程序中通常指調用頁面,普遍狀況下指的是包含它的函數做爲方法被調用時所屬的對象。直接修改this.data是無效的,沒法改變頁面的狀態,還會形成數據的不一致。單次設置的數據有一個大小限制,不能超過1024KB,避免一次性設置過多的數據。
setData()函數的參數接受一個對象。以key,value的形式表示,將this.data中的key對應的值改變爲value。key能夠很是靈活,包括以數據路徑的形式表示,如array[0].title,而且無需在this.data中預約義。
使用微信提供的現成數據API接口,如:
wx.getStorage:獲取本地數據緩存
wx.setStorage:設置本地數據緩存
wx.clearStorage:清理本地數據緩存
上傳或下載文件的API接口,如:
wx.request:發起網絡請求
wx.uploadFile:上傳文件
wx.downloadFile:下載文件
wx.navigateTo:保留當前頁面,跳轉到應用內的某個頁面。可是不能跳到 tabbar 頁面。可返回原頁面。
wx.redirectTo:關閉當前頁面,跳轉到應用內的某個頁面。可是不容許跳轉到 tabbar 頁面。不可返回原頁面。
以上就是微信小程序框架的相關描述,微信團隊一直在不斷的優化框架能力,及時的關注官方提供的小程序開發者文檔,瞭解小程序的最新能力及優化點。