小程式框架原理之渲染流程及通信流程

来源:https://www.cnblogs.com/chanwahfung/archive/2020/05/21/12934057.html
-Advertisement-
Play Games

MINA MINA 是在微信中開發小程式的框架。其目標是通過儘可能簡單、高效的方式讓開發者可以在微信中開發具有原生 APP 體驗的服務。 MINA 提供了自己的視圖層描述語言 WXML 和 WXSS,以及基於 JavaScript 的邏輯層框架,核心是一個響應的數據綁定系統。整個系統分為視圖層(Vi ...


MINA

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

MINA 提供了自己的視圖層描述語言 WXMLWXSS,以及基於 JavaScript 的邏輯層框架,核心是一個響應的數據綁定系統。整個系統分為視圖層(View)和邏輯層(App Service),併在視圖層與邏輯層間提供了數據傳輸和事件系統,可以讓開發者可以方便的聚焦於數據與邏輯上。

MINA 讓數據與視圖保持同步非常簡單。當做數據修改的時候,只需要在邏輯層修改數據,視圖層就會做相應的更新。MINA 是騰訊給微信小程式命名的框架,實際上應用的是目前業界最著名的 MVVM 模式。

wxml的真實面目

我們都知道小程式提供了很多方便快捷的自定義組件(標簽),但你知道小程式的這些組件編譯過後會渲染成什麼嗎?先說答案,其實 wxml 經過編譯後會渲染成 html 。很簡單的一點,你發現在小程式內編寫 html 標簽,最終也可以運行。

探尋

光說可能體會不到,下麵開始探尋小程式真實渲染的樣子。先看下開發者工具內 wxml 的內容,待會和真實渲染的內容做對比。

接下來一步步找到小程式 wxml 渲染完成的真實樣子,工具菜單欄點擊微信開發者工具,選擇調試微信開發者工具。打開的控制台可以調試整個微信開發者工具,用調試箭頭指向小程式內容區域,這時可以看到小程式視圖層是被嵌套在 webviewiframe 內。

但是當我們點開 iframe 是無法查看到裡面內容的。如果想要查看調試 webview,只需選中 webview 打開它的調試工具即可,在控制台輸入以下代碼:

$$('webview')[0].showDevTools(true)

可以看到又打開了一個調試視窗,這裡面就是小程式視圖層渲染的真實樣子:

可以看到結構和 wxml 里的內容幾乎一模一樣,只是 topbar 變成了 wx-topbarview 變成了 wx-view等。這些都是內部實現的一套對應小程式標簽的 webComponent 組件,而 webComponent 實際渲染出來還是 html 標簽。

轉換過程

轉換過程是微信開發者工具內部通過一個可執行編譯工具實現對小程式文件轉換。在微信開發者工具控制台輸入 openVendor() 會打開一個文件夾,裡面存放著微信的基礎庫及工具,在裡面可以找到 wcc.exewcsc.exe 執行文件,分別對應 wxmlwxss 的文件轉換。

該工具可以單獨對小程式文件進行轉換,使用方法 ./wcc -d wxml文件路徑 >> 輸出路徑。例如,將工具複製到一個文件夾內,再將一個 wxml 放入該文件夾內,命令行輸入 :

./wcc -d index.wxml >> index.js

可能有人很好奇為什麼是生成 js 文件,而不是 html 文件。原因很簡單,因為需要處理 wxml 的動態綁定數據。看看這個 js 文件生成的是什麼:

因為這些都是混淆壓縮過的代碼,基本沒有可讀性。這裡只需要註意一個函數就好,那就是 $gwx。這是個很關鍵的函數,它的作用是生成虛擬dom樹,用於渲染真實節點。

接下來回到 webview 調試視窗,在 head 內找到這段插入的 script 標簽代碼:

有沒有很熟悉,沒錯,就是和上面轉換後的代碼是同一個東西。也就是說,我們的 wxml 文件通過編譯,最終在視圖層中執行的就是這段 js 代碼(這裡只是可以大概這麼理解,實際需要向邏輯層獲取數據才能渲染頁面)。控制台輸入 $gwx 發現這個函數存在,那麼這個函數如何生成虛擬dom呢?$gwx 函數的第一個參數接收一個路徑參數,這個路徑就是 wxml 文件路徑,此時在控制台輸入:

let generateFunc = $gwx('./pages/index/index.wxml')
generateFunc()

這時頁面虛擬dom就生成出來了:

單純調用 generateFunc 生成出來的虛擬dom是沒有動態綁定數據的,如果想要動態的綁定數據,在調用 generateFunc 時傳入一個數據對象。但是數據全在邏輯層里,這時就需要進行通信了。

數據通信

首先要知道小程式時運行在基礎庫之上的,但它們都是壓縮打包好的,後面找到反編譯出來的基礎庫代碼,其中最重要的就是 WAService.jsWAWebview.js,它們分別是視圖層和邏輯層的核心實現。

它們之間需要一個橋梁來進行通信,那就是 JS BridgeJS Bridge 提供調用原生功能的介面(攝像頭,定位等),它的核心是構建原生和非原生間消息通信的通道,而且這個通信的通道是雙向的。通過 JS Bridge 的發佈訂閱方法,視圖層和邏輯層進行數據通信。

通信流程

接下來看看視圖層和邏輯層的交互流程:

  1. wxml 轉換成對應的 js 文件,等待生成虛擬dom函數 $gwx 準備完成,使用 dispatchEvent 通知 WAWebview
  1. WAWebview 監聽到 generateFuncReady 事件觸發,使用 WeixinJSBridge.publish 向邏輯層通信。
  1. 邏輯層處理邏輯,也就是我們平常寫的小程式 js 文件里的東西,然後通過 JS Bridge 通知並返回數據給視圖層。

  2. 視圖層接收到數據,將數據傳入生成虛擬dom的函數內,渲染頁面,當然小程式也有相應的diff演算法。

例如在 wxml 中綁定一個動態數據 title,視圖層接收到數據後,重新生成虛擬dom

generateFunc({
  title'標題'
})
  1. 初始化完成後,就會走對應的其他生命周期,或者用戶觸發事件,數據都會在邏輯層處理完成後通過 JS Bridge 通知到視圖層,視圖層再次調用生成虛擬dom的函數,更新頁面。

wxss如何工作

wxss 工作原理和 wxml 差不多,都是通過工具轉換為 js。為什麼又是轉換成 js,因為有 rpx 單位,需要根據手機尺寸進行設置 px

wcsc.exe 轉換命令如下:

./wcsc -js index.wxss >> index.js

可以看到文件開頭就是對 rpx 的轉換

之後創建 style 標簽,動態添加到視圖層中

最後

附上 WAService.jsWAWebview.js 的代碼作為學習參考。


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

-Advertisement-
Play Games
更多相關文章
  • 首先我的伺服器是Centos7.6。低於7版本的小伙伴不可照搬。 我選擇的是使用rpm的方式進行安裝,比較方便。 "kudu安裝包下載地址" ctrl+f 查找kudu,這6個rpm包都要下載下來,推薦使用迅雷下載 在下載的時候我們還需要做一些準備工作。執行以下命令,安裝必備的包。 沒有安裝ntp的 ...
  • Redis的主從複製是如何工作的?如何在同步數據的同時,還保持著高性能,你瞭解嗎? https://redis.io/topics/replication 註意以下基於 redis 5 最新版本, 名詞和配置項已經被官方改為 ,其實是一個東西,都指從節點。 主從複製的基本流程 主 與 從 複製的基本 ...
  • NTP時鐘伺服器(NTP校時伺服器)日常維護與實施 NTP時鐘伺服器(NTP校時伺服器)日常維護與實施 京準電子科技VX——ahjzsz 京準電子科技有限公司主營ntp網路時鐘伺服器,時鐘同步產品, 產品正在國內外各行業近萬個現場穩定運行,現就設備安裝、日常維護及解決方案做下總結。 一、NTP網路時 ...
  • oracle11g,安裝完成之後直接使用,今天用PLSQL鏈接突然報錯,報錯代碼為:ORA-12514:監聽程式當前無法識別連接描述符中請求的服務。網上查了這種異常的解決辦法,特在此記錄。 出現該問題一般有兩種情況。 第一種是在你安裝完之後未配置監聽(在此我暫時忘記安裝完之後有沒有配置監聽); 第二 ...
  • 一:新建表和欄位建議: 1.所有數據表和欄位要有清晰的註釋,欄位說明 說明:不管是創建者還是其他開發或者後續維護者都能清楚知道數據表和欄位定義的含義 2.表名、欄位名使用小寫字母或數字,禁止出現數字開頭 說明:MySQL在Windows下不區分大小寫,但在Linux下預設是區分大小寫,為了避免出現不 ...
  • 用戶畫像 簡介 ​ 用戶畫像,作為一種勾畫目標用戶、聯繫用戶訴求與設計方向的有效工具,用戶畫像在各領域得到了廣泛的應用。 用戶畫像最初是在電商領域得到應用的,在大數據時代背景下,用戶信息充斥在網路中,將用戶的每個具體信息抽象成標簽,利用這些標簽將用戶形象具體化,從而為用戶提供有針對性的服務。 ​ 還 ...
  • 網路地圖服務(WMS) 網路地圖服務(WMS)利用具有地理空間位置信息的數據製作地圖。其中將地圖定義為地理數據可視的表現。能夠根據用戶的請求返回相應的地圖(包括PNG,GIF,JPEG等柵格形式或者是SVG和WEB CGM等矢量形式)。WMS支持網路協議HTTP,所支持的操作是由URL定義的。 先來 ...
  • JavaScript是基於==詞法作用域==的語言:通過閱讀包含變數定義在內的數行源碼就能知道變數的作用域。全局變數在程式中始終都是有定義的。==局部變數在聲明它的函數體內以及其所嵌套的函數內始終是有定義的。== 如果將一個局部變數看做是自定義實現的對象的屬性的話 ,那麼可以換個角度來解讀變數作用域 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...