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

来源: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
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...