微信小程式開發框架(MINA)詳解

来源:https://www.cnblogs.com/idreamo/archive/2019/05/17/10867241.html
-Advertisement-
Play Games

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


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

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

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:'我的小程式'
    })
  }
})

        

圖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編寫,在此基礎上,微信團隊做出了一些優化,以便更高效的開發小程式,這些優化包括:

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 頁面。不可返回原頁面。

 以上就是微信小程式框架的相關描述,微信團隊一直在不斷的優化框架能力,及時的關註官方提供的小程式開發者文檔,瞭解小程式的最新能力及優化點。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 先用SYS登陸SQLPLUS,即: 再給scott授權: ...
  • 一、文件下載: MySQL:官網:https://www.mysql.com/downloads/(現在最新的是5.7版) 下載路徑:"Downloads" ==>> "Community" ==>> "MySQL Community Server" ==>>"Looking for previou ...
  • JSON 可謂風靡互聯網,在數據交換使用上,其優勢特別明顯,其結構簡潔、可讀易讀、形式靈活。很多 API 介面的數據都採用 JSON 來表示。 PostgreSQL 對 JSON 提供了良好的支持。具體的相關函數可參考: "JSON類型和函數" 從使用的角度而言,個人覺得常見的應用場景為: 1. 讀 ...
  • 當然首先要裝好Oracle 11g 然後還要有sqlplus,這個在Oracle11g的時候應該都會配上的 進入正題,如果oracle/plsql沒scott賬戶,如何創建 先找到Oracle安裝目錄下的soctt.sql 我的是在: E:\app\91959\product\11.2.0\dbho ...
  • (1)連接資料庫時報錯 錯誤原因是和轉義字元有關。連接字元串使用的URL格式,所以其中的密碼中的% 需要轉義。 知識擴展: 連接mongo使用URI有特殊字元 '@' 或者":"或者‘%’, 連接會報錯,需要進行轉義。 解決方法: 把 @ 換成 %40 把 : 換成 %3A 把 % 換成 %25 ( ...
  • 1. 現象與問題 ORDER BY排序後,用LIMIT取前幾條,發現返回的結果集的順序與預期的不一樣 下麵是我遇到的問題: 可以看到,帶LIMIT與不帶LIMIT的結果與我預期的不一樣,而且“很不可思議”,真是百思不得其解 後來百度了一下,如果order by的列有相同的值時,mysql會隨機選取這 ...
  • 問題的提出 在項目中,有些表的記錄增長非常快,記錄數過大時會使得查詢變得困難,導致整個資料庫處理性能下降。此時,我們會考慮按一定的規則進行分表存儲。 常用的分表方式是按時間周期,如每月一張,每天一張等。當每月或每天首條記錄到達時,根據表結構創建該周期為尾碼的表進行存儲。 相關考慮 這其中主要考慮兩個 ...
  • 一、MySQL5.7的卸載 1.1yum方式查看yum是否安裝過mysql cd yum list installed mysql* 如或顯示了列表,說明系統中有MySQL 如上顯示,我已經安裝了mysql,共有4項 1.2yum卸載mysql 將列表中出現的名字全部卸載掉 yum remove m ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...