《微信小程序架構解析》丨NOTES


作者什么來頭

渠宏偉,騰訊前端開發(fā)高級工程師程储。

小程序特點

類Web章鲤,不是HTML5

即用即走,隨手可得

擁有離線能力

基于微信跨平臺

媲美原生操作體驗

為什么那么快

Page Frame

Native預先加載一個WebView

當打開指定頁面時帚呼,無需加載額外資源直接渲染

返回顯示歷史View

退出小程序,View狀態(tài)不銷毀

小程序入口

掃碼進入

搜索(模糊)

發(fā)現>小程序

小程序發(fā)送到桌面(Android)

小程序架構


交互通過系統(tǒng)層的JSBridge進行眷蜈,當用戶進行操作觸發(fā)了事件沈自,通過JSBridge通知邏輯層枯途,邏輯層執(zhí)行對應邏輯并把數據通過JSBridge傳遞給視圖層,視圖層執(zhí)行相應的操作酪夷。


小程序初始化時晚岭,先從微信的CDN下載小程序的完整的包,然后在微信內部進行解包初始化辅甥。

小程序視圖層

WXML(WeiXin Markup Language)

支持數據綁定

支持邏輯算術燎竖、運算

支持模板构回、引用

支持添加事件


WXML先被編譯成JS文件疏咐,引入數據后會初始完成虛擬DOM,最終把虛擬DOM構建成DOM樹借跪,在WebView中渲染酌壕。

WXSSWeiXin Style Sheets

支持大部分CSS特性

添加尺寸單位rpx卵牍,可根據屏幕寬度自適應

使用@import語句可以導入外聯(lián)樣式表

不支持多層選擇器,避免被組件內結構破壞


WXSS被編譯成JS運行辛掠。常用選擇器、組件回挽,略過欠气。

小程序的組件基于Web Component標準,使用Polymer框架實現Web Component队塘。Polymer框架是Google提出的宜鸯,但在使用過程中發(fā)現其性能較低淋袖,所以微信自研了一套。

Native組件層在WebView層之上焰情。

小程序邏輯層

邏輯層講數據進行處理后發(fā)送給視圖層剥懒,同時接受視圖層的事件反饋。

App()小程序的入口验游;Page()頁面的入口

提供豐富的API保檐,如微信用戶數據,掃一掃垒在,支付等微信特有能力

每個頁面有獨立的作用域扔亥,并提供模塊化能力

數據綁定,事件分發(fā)推盛,生命周期管理谦铃,路由管理

運行環(huán)境:iOS-JSCore、Android-X5 JS解析器瘪菌、DevTool-nwjs Chrome內核

邏輯層生命周期

用戶從微信打開一個小程序的執(zhí)行過程:

Native執(zhí)行一個拉起的操作师妙,告訴App Service層

App Service層執(zhí)行拉起,同時通知View層進行初始化

接下來要打開頁面怔檩,通過路由通知App Service層

App Service層創(chuàng)建一個Page蓄诽,然后通知Web層初始化仑氛,同時通知View層渲染并發(fā)送初始化數據

App Service層的Page會進行onLoad、onShow事件的執(zhí)行锯岖,渲染完成onReady

當用戶進行操作時出吹,就出發(fā)一次用戶事件,用戶事件會通知到App

Service層并在此層執(zhí)行赃额,然后通知View層進行局部渲染叫确,這樣就完成了一次交互芍锦。

New View是在Web View初始化完成之后建立的娄琉,用于等待用戶執(zhí)行下一個界面時使用,減少Web View創(chuàng)建的花銷孽水,用戶不需要等待了女气。App Service層的New Page也是同理。

小程序可以借鑒的優(yōu)點

提前新建Web View缘滥,準備新頁面渲染

View層和邏輯層分離,通過數據驅動赃阀,不直接操作DOM

使用Virtual DOM擎颖,進行局部更新

全部使用https,確保傳輸過程中安全

前端組件化開發(fā)

加入rpx單位肖抱,隔離設備尺寸异旧,方便開發(fā)

小程序存在的問題

小程序仍然使用WebView渲染吮蛹,并非原生渲染

需要獨立開發(fā),不能再非微信環(huán)境運行

開發(fā)者不可以擴展新組件

服務端口返回的頭無法執(zhí)行术荤,如Set-Cookie

以來瀏覽器環(huán)境的js庫不能使用每篷,因為是JSCore執(zhí)行的,沒有window子库、document對象

WXSS中無法使用本地(圖片矗晃、字體等)

WXSS轉化成js而不是css,為了兼容rpx

WXSS不支持級聯(lián)選擇器

小程序無法打開頁面张症,無法拉起APP

脫離微信的“小程序”:PWA漸進式應用

優(yōu)點:

漸進增強:支持的新特性的瀏覽器獲得更好的體驗俗他,不支持的保持原來的體驗

離線訪問:通過Service Workers可以再離線或者網速差的環(huán)境下工作

類原生應用:使用app shell model做到原生應用般的體驗

可安裝:允許用戶保留對他們有用的應用在主屏幕上,不需要通過應用商店

容易分享:通過URL可以輕松分享應用

持續(xù)更新:受益于service worker的更新進行地沮,應用能夠始終保持更新

安全:可通過https來提供服務來防止網絡窺探,保證內容不被篡改

可搜索:得益于W3C manifests元數據和service worker的等級周伦,讓搜索引擎能夠找到wen應用

再次訪問:通過消息推送等特性讓用戶再次訪問變得容易

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末专挪,一起剝皮案震驚了整個濱河市片排,隨后出現的幾起案子,更是在濱河造成了極大的恐慌迫卢,老刑警劉巖乾蛤,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件捅僵,死亡現場離奇詭異庙楚,居然都是意外死亡,警方通過查閱死者的電腦和手機酪捡,發(fā)現死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進店門逛薇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來塞祈,“玉大人帅涂,你說我怎么就攤上這事∷挂椋” “怎么了醇锚?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長看靠。 經常有香客問我液肌,道長,這世上最難降的妖魔是什么谤祖? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任粥喜,我火速辦了婚禮,結果婚禮上橘券,老公的妹妹穿的比我還像新娘额湘。我一直安慰自己,他們只是感情好旁舰,可當我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布缩挑。 她就那樣靜靜地躺著,像睡著了一般鬓梅。 火紅的嫁衣襯著肌膚如雪供置。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天绽快,我揣著相機與錄音芥丧,去河邊找鬼。 笑死续担,一個胖子當著我的面吹牛,可吹牛的內容都是我干的活孩。 我是一名探鬼主播物遇,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼憾儒!你這毒婦竟也來了询兴?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤起趾,失蹤者是張志新(化名)和其女友劉穎诗舰,沒想到半個月后,有當地人在樹林里發(fā)現了一具尸體训裆,經...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡眶根,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年蜀铲,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片属百。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡记劝,死狀恐怖,靈堂內的尸體忽然破棺而出族扰,到底是詐尸還是另有隱情隆夯,我是刑警寧澤,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布别伏,位于F島的核電站蹄衷,受9級特大地震影響,放射性物質發(fā)生泄漏厘肮。R本人自食惡果不足惜愧口,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望类茂。 院中可真熱鬧耍属,春花似錦、人聲如沸巩检。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽兢哭。三九已至领舰,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間迟螺,已是汗流浹背冲秽。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留矩父,地道東北人锉桑。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像窍株,于是被迫代替她去往敵國和親民轴。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,792評論 2 345

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,510評論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理球订,服務發(fā)現后裸,斷路器,智...
    卡卡羅2017閱讀 134,599評論 18 139
  • 是不是 非要淚水已漸干涸雙眼 才會像孩子一樣清澈 會不會 定要千瘡百孔的傷痕心靈...
    麥麥麥麥芽糖閱讀 221評論 3 3
  • 感恩美味的蛋糕辙售,帶著祝福和儀式感轻抱,讓伊伊步入六歲,非常好吃旦部,謝謝 感恩快遞師傅大熱天及時送來快遞祈搜,謝謝你 感恩林暉...
    妮妮Gloria閱讀 185評論 0 3
  • 異步編程一直是JavaScript 編程的重大事項。關于異步方案士八, ES6 先是出現了 基于狀態(tài)管理的 Promi...
    Jeremy_young閱讀 16,911評論 2 44