亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序開發框架MINA的示例分析

發布時間:2021-08-18 15:25:25 來源:億速云 閱讀:234 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關微信小程序開發框架MINA的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

小程序MINA框架,及優點

MINA框架:

小程序使用的是MINA框架,目的是通過簡單、高效的方式讓開發者可以在微信中開發具有原生App體驗的服務。   

MINA的核心是一個響應的數據綁定系統。

 整個系統分為兩塊:視圖層(view,描述語言wxml和wxss)和邏輯層(App Serice,基于 JavaScript)。這可以讓數據與視圖非常簡單的保持同步。當做數據修改時,只需要在邏輯層改數據,視圖層就會做響應的更新。開發者只需要將頁面路由、方法、生命周期函數注冊進框架,其他的一切復雜的操作都將由框架處理。

小程序優點:

? 方便使用:無需下載,打開即用,用完即走。不占用手機內存,省流量,省安裝時間
? 開發簡單:開發的本質是MVVM風格的Javascript框架上開發的,有前端經驗的程序員可以無縫銜接,無經驗的“小白”也可以快速入門。
? 跨平臺運行:不用再分別開發IOS和Andriod版本,只需要發布微信小程序平臺,所有平臺都可以使用。開發成本低
? 快速分發與迭代:無需關心各種發布渠道,也無須擔心舊版本升級的兼容問題。 

 打開速度比H5快,體驗接近原生APP

小程序開發框架的目標是通過盡可能簡單、高效的方式讓開發者可以在微信中開發具有原生 APP 體驗的服務。

微信團隊為小程序提供的框架命名為MINA。MINA框架通過封裝微信客戶端提供的文件系統、網絡通信、任務管理、數據安全等基礎功能,對上層提供一整套JavaScript API,讓開發者方便的使用微信客戶端提供的各種基礎功能與能力,快速構建應用。

MINA框架

微信小程序的框架示意圖如下所示:

微信小程序開發框架MINA的示例分析

MINA框架主要分為兩大部分:

第一部分頁面視圖層,開發者使用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:'我的小程序'
 })
 }
})

微信小程序開發框架MINA的示例分析 微信小程序開發框架MINA的示例分析

圖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目錄。

微信小程序開發框架MINA的示例分析

邏輯層

小程序的邏輯層就是所有.js腳本文件的集合。小程序在邏輯層處理數據并發送至視圖層,同時接受視圖層發回的事件請求。

MINA框架的邏輯層是由JavaScript編寫,在此基礎上,微信團隊做出了一些優化,以便更高效的開發小程序,這些優化包括:

1、增加app方法用來注冊程序,增加page方法用來注冊頁面;

2、提供豐富的API接口;

3、頁面的作用域相對獨立,并擁有了模塊化的能力;

簡單概括,邏輯層就是各個頁面的.js腳本文件。

需要注意的是,小程序的邏輯層由js編寫,但并不是在瀏覽器中運行的,所以JavaScript在Web中的一些能力都不能使用,比如 dom、window等,這也是我們開發過程中要克服的阻礙。

視圖層

對于微信小程序而言,視圖層就是所有的.wxml(WeiXin Markup language)文件與.wxss(WeiXin Style Sheet)文件的集合:.wxml用于描述頁面結構而.wxss用于描述頁面樣式。

視圖層以給定的樣式來展現數據并反饋事件給邏輯層,而數據展現是以組件來進行的。組件(Component)是視圖的基本組成單元。

數據層

數據層包括臨時數據或緩存、文件存儲、網絡存儲與調用。

1、頁面臨時數據或緩存

在頁面page()中,我們要使用setData函數來將數據從邏輯層發送到視圖層,同時改變對應的this.data的值。this在小程序中一般指調用頁面,廣泛情況下指的是包含它的函數作為方法被調用時所屬的對象。直接修改this.data是無效的,無法改變頁面的狀態,還會造成數據的不一致。單次設置的數據有一個大小限制,不能超過1024KB,避免一次性設置過多的數據。

setData()函數的參數接受一個對象。以key,value的形式表示,將this.data中的key對應的值改變為value。key可以非常靈活,包括以數據路徑的形式表示,如array[0].title,并且無需在this.data中預定義。

2、文件存儲(本地存儲)

使用微信提供的現成數據API接口,如:

wx.getStorage:獲取本地數據緩存

wx.setStorage:設置本地數據緩存

wx.clearStorage:清理本地數據緩存

3、網絡存儲與調用

上傳或下載文件的API接口,如:

wx.request:發起網絡請求

wx.uploadFile:上傳文件

wx.downloadFile:下載文件

調用URL的API接口如下:

wx.navigateTo:保留當前頁面,跳轉到應用內的某個頁面。但是不能跳到 tabbar 頁面。可返回原頁面。

wx.redirectTo:關閉當前頁面,跳轉到應用內的某個頁面。但是不允許跳轉到 tabbar 頁面。不可返回原頁面。

關于“微信小程序開發框架MINA的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巴彦淖尔市| 新化县| 库尔勒市| 吴旗县| 加查县| 保亭| 壤塘县| 囊谦县| 于都县| 岢岚县| 开封县| 六枝特区| 安图县| 都昌县| 旺苍县| 博湖县| 丰县| 新沂市| 库伦旗| 珲春市| 边坝县| 高雄县| 皋兰县| 西乌珠穆沁旗| 荥经县| 弥勒县| 翁源县| 响水县| 宕昌县| 雷山县| 井研县| 门头沟区| 宝坻区| 昌乐县| 鸡东县| 江北区| 定襄县| 凭祥市| 叶城县| 昔阳县| 永泰县|