亚洲视频二区I天堂网av 在线I丰满人妻AV一区二区三I088精品在线观看视频IAV在线网站免费I亚洲人成影院在线I91精品91久久久777777I131M久I日日摸日日

027-81331413

實現(xiàn)微信小程序最新運行環(huán)境系列

發(fā)布時間:2020-10-31 瀏覽:2532

實現(xiàn)微信小程序編譯和運行環(huán)境系列 (初始篇)

前言

最近一段時間在研究實現(xiàn)微信小程序和小游戲編譯打包和運行環(huán)境平臺開發(fā)。

目前基本可以支持微信基礎(chǔ)庫 2.8.2 功能迭代了。

所以想通過記錄分享一下自己的認知過程中遇到的一些問題和解決方案來更好的理解小程序設(shè)計上的優(yōu)點和一些不足的地方。

在此之前網(wǎng)上有存在開源的一些基于微信基礎(chǔ)庫版本 1.0 的一些參考。核心作者是由開源大牛 啟明兄 的 wept 項目基礎(chǔ)上構(gòu)建的 (目前有幸和啟明兄成為同事對這個小程序整體的架構(gòu)理解幫助了我很多)。

由于 wept 的運行環(huán)境是基于微信基礎(chǔ)庫 1.0 的版本上實現(xiàn)之后也不維護了,時間上是 2016 的在后續(xù)的更新的版本中新加的一些特性如自定義組件 npm 包很多 api 等開發(fā)實現(xiàn)都不支持,最主要是的微信在后續(xù)架構(gòu)中更換底層的通信方式采用了 webstock 的方式等一些其他變化。

正文

后面我會通過幾篇文章來整體描述一下從工具到破解到源碼解析和原理到實現(xiàn)的處理流程

最開始的時候也在網(wǎng)上找了很多的資料,看了有一些人寫的解析微信小程序架構(gòu)的文章,從中學(xué)習(xí)了解了很多,

但如果想模擬實現(xiàn)出來這么個東西還是有蠻迷糊的,所以我想通過我們所實現(xiàn)的過程來一點點 從現(xiàn)象 看本質(zhì) 來解析下微信小程序編譯和運行原理。

凡事對自己多點信心,多堅持下,多學(xué)習(xí)下,想想我們遇到的問題,當時感覺我,搞不定了,弄不了,最后隨著時間的推移和認知的迭代問題總會慢慢消滅掉。

本文將先通過全面解析微信開發(fā)者工具來知道那些基本的文件和內(nèi)容組成一一講述 (從現(xiàn)象 看本質(zhì))。

在此之前我們通過官方文檔可以了解一些內(nèi)容

  • 整個小程序框架系統(tǒng)分為兩部分:邏輯層(App Service)和 視圖層(View);

  • 小程序提供了自己的視圖層描述語言 WXML 和 WXSS;

  • 基于 JavaScript 的邏輯層框架,并在視圖層與邏輯層間提供了數(shù)據(jù)傳輸和事件系統(tǒng)他們兩個線程里運行;

  • 視圖層使用 WebView 渲染,邏輯層使用 JSCore 運行, 視圖層和邏輯層通過系統(tǒng)層的 JSBridage 進行通信,邏輯層把數(shù)據(jù)變化通知到視圖層,觸發(fā)視圖層頁面更新,

    視圖層把觸發(fā)的事件通知到邏輯層進行業(yè)務(wù)處理。

從上述說明中我們可以得知一些重要信息邏輯層(App Service)和 視圖層(View) 以及兩者之間的通信協(xié)調(diào)。

下面通過微信開發(fā)工具來展示說明,小程序邏輯層的 javascript 代碼是運行在 NW.js 中,視圖層是由 Chromium 60 Webview 來渲染的

他們之間是通過 webstock 協(xié)議來通信的。

以下我們主要是以 mac 環(huán)境為主

我們先打開 微信開發(fā)工具官方 demo 如圖:

從上圖和我們的一些理解我們知道微信小程序的文件格式主要組成:

  • .js 主要頁面邏輯;

  • .wxml 頁面結(jié)構(gòu),框架設(shè)計的一套標簽語言,結(jié)合基礎(chǔ)組件、事件系統(tǒng),可以構(gòu)建出頁面的結(jié)構(gòu);

  • .wxss 是一套樣式語言,用于描述 WXML 的組件樣式;

  • .json 頁面配置按照『約定優(yōu)于配置』的原則。

接下來我們先找到本機微信開發(fā)者工具應(yīng)用包里面如圖

我們后面分析的主要代碼都在 package.nw 里面和 core.wxvpkg。

這些文件在后面實現(xiàn)過程中都會使用說明用途的。

  • js 文件里面的內(nèi)容主要是在頁面和邏輯層的渲染用,后面將會看到;

  • core.wxvpkg 是這個里面的核心文件破解這個包可以知道很多邏輯可以先給大家看下解壓后包的結(jié)構(gòu):

core.wxvpkg 解壓代碼上傳在 unwxvpkg 大家有興趣可以自己先試試。

接下來我們回到開發(fā)者工具中打開:

微信開發(fā)者工具–》調(diào)試–》調(diào)試微信開發(fā)者工具

打開調(diào)試后我們可以看到的界面如下:

從上面的現(xiàn)象我們可以看出他的兩層渲染層和邏輯層結(jié)構(gòu)是包含在兩個 webview 里面

第一個對應(yīng)的 webview 是渲染層的每個頁面都對應(yīng)一個地址

但邏輯層 appservice 只有一個不變的

下來我們可以看看這個 webview 里面是個什么東

如果我們直接把 view 層的 webview 標簽改成 iframe 的話

可以看到微信就直接不在里面展示給你頁面白屏了

如果你更改 appservice 的 webview 的話微信還會給你各種 alert 彈框,反正應(yīng)該就是不想讓你分析他的代碼

點擊確定消都消不了只能重新重啟編譯了 有點小惡心啊

居然不讓我們正大光明的看,那我們只能搞一些旁門左道來破壞了

我們第一步還是打開:微信開發(fā)者工具–》調(diào)試–》調(diào)試微信開發(fā)者工具

在控制臺輸入

 復(fù)制代碼

document.getElementsByTagName('webview')

可以看到對應(yīng)的有 4 個 webview, 我們先要關(guān)注的是第一個 webview 因為你點開可以發(fā)現(xiàn)第一個對應(yīng)的就是渲染層的 webview

后面的幾個可以先不關(guān)注,后續(xù)我們會詳解

然后我們執(zhí)行命令打開第一個 webview:

 復(fù)制代碼

document.getElementsByTagName('webview')[0].showDevTools(true,null)

可以看到如圖

現(xiàn)在我們就可以看到微信頁面渲染層的頁面結(jié)構(gòu)了

(這里說明下本篇文章中文件里面的內(nèi)容每一個文件的來源和用途,我都會在后續(xù)章節(jié)中講解出來 因為里面涉及的內(nèi)容過多 我怕放在一篇文章里會太長大家看了會厭煩,所以我會分為幾篇來說明,后面的 appservice 和 一些基礎(chǔ)包和 WAWebview.js WAService.js 以及使用的同步 api 和請求在頁面的 appservice.js 等等,在本篇中只會簡單描述出來 不做過多講解,后續(xù)會逐步更新)

上面的 webview 可以找到對應(yīng)的頁面層的結(jié)構(gòu),那么 appservice 要怎么找到呢?

其實最簡單的我們直接在首頁里面的控制臺打 document 就可以直接看到展示的邏輯層代碼

(我的做法是從寫了微信的 alert 和基礎(chǔ)庫的一些文件都可以看到這個結(jié)構(gòu))

注意點在微信小游戲里面微信重寫了 window 和 document 對象 所以不能直接按照我們平常操作頁面那樣使用

接下面我們看下微信小程序的基礎(chǔ)庫庫文件

方法是我們在首頁控制臺里面輸入 openVendor()

我們可以看到彈出的文件系統(tǒng),這里面對應(yīng)的就是你選擇本地的

詳情 ==》調(diào)試基礎(chǔ)庫 ==》選擇基礎(chǔ)庫版本

  • .wxvpkg 文件就是每個基礎(chǔ)庫版本的包我們,解壓這個包我們可以看到他的組成;

  • wcc 可執(zhí)行程序,用于將 wxml 轉(zhuǎn)為 view 模塊使用的 js;

  • wcsc 可執(zhí)行程序,用于將 wxss 轉(zhuǎn)為 view 模塊使用的 css。

.wxvpkg 包里面這個基礎(chǔ)庫文件的 WAWebview.js 和 WAService.js,對應(yīng)這兩個 webview 里面的 js 引用你可以仔細觀察下.wxvpkg 文件解包后的格式:

解壓.wxvpkg 格式包的代碼地址 github

對于 wcc 和 wcsc 源碼現(xiàn)在沒必要去研究他,但我們可以通過腳本劫持方法可以看到他運行了什么命令操作

這里告訴大家一個方法劫持他的運行命令

找到微信開發(fā)者工具 wcc 和 wcsc 的地方然后新建兩個同名的腳本,然后把原文件從命名,然后重啟微信開發(fā)者工具 一定要重啟不然不生效

wcc wcsca 劫持腳本代碼地址 github

然后我們到首頁控制臺還是輸入 openVendor() 可以看到輸出的文件

從上面這個圖就可以看出下面這個圖里面我們可以認知到一些信息

  • 首次加載的時候 wcc 執(zhí)行了 -ds -d - xc…和 -ds -d - cc…結(jié)構(gòu)的命令可以看到微信首次把所有.wxml 都執(zhí)行了

  • 可以看到參數(shù)里面有個數(shù)字其實他對應(yīng)的有幾種.wxml 文件形式向只存在.wxml 和自定義組件等一些格式他是沒計算在內(nèi)的

  • -xc -cc 其實對應(yīng)就是下面圖兩個邏輯層和渲染層里面的 js 方式

  • 我發(fā)現(xiàn)當我們修改一個.wxml 里面一點改動的時候,微信又會全部從新編譯執(zhí)行這些命令很耗時這點其實可以改進的。

  • 另一個微信開發(fā)者工具感覺做的不友好的地方是大于 500KB 的 javascript 文件不做給你做 es6 轉(zhuǎn)換和壓縮,就算你設(shè)置了微信也不會給你轉(zhuǎn),可以在 source 里面的資源可以看出。

wcc 執(zhí)行的命令最終生成的就是邏輯層和渲染層的 $gwxc() 方法里面的 js 代碼,大家可以自己手動測試下就會發(fā)現(xiàn)。

wxss 生成的主要是渲染層 eval() 這一坨代碼

本篇只是簡單描述了一些關(guān)鍵文件的描述。

后面我會對關(guān)鍵文件進行一一分析描述下他具體做了什么,為什么用到它。

下一篇會給大家?guī)礓秩緦雍瓦壿媽拥木唧w頁面文件內(nèi)容結(jié)構(gòu)解析,以及 webstock 通信架構(gòu)在微信開發(fā)者工具里面的運用,可以先給大家看下。


主站蜘蛛池模板: 香港三级精品三级在线专区 | 中文字幕高清 | 黄色一级视频免费看 | 中文人妻熟妇乱又伦精品 | 欧美黑人孕妇孕交 | 国产主播毛片 | 日韩国产欧美一区二区三区 | 日本成片区免费久久 | 中国女人黄色大片 | 亚洲成a∧人片在线播放无码 | 欧美日韩一区二区视频在线观看 | 天天躁恨躁夜躁2020优势对比 | 国产精品亚洲а∨天堂免下载 | 亚洲人成网站在线播放无码 | 成人黄色a| 亚洲一区二区三区视频在线 | 色一情一乱一乱一区免费网站 | 成人做爰999 | 日韩性欧美 | 国产精品无码a∨果冻传媒 性无码专区无码 | 国产成人精品男人的天堂 | 亚洲国产精品无码久久电影 | 国产亚洲制服免视频 | 男女男精品视频网站 | 亚洲精品一区二区三区高潮 | 99精产国品一二三产区区别麻豆 | 美国三级日本三级久久99 | 欧美日韩大片在线观看 | 干日韩美女 | 久久依人 | 无码人妻精品一区二区三区99仓本 | 91精品国产自产91精品 | 亚洲欧美一级久久精品国产特黄 | 亚洲男人av天堂男人社区 | 成人免费无遮挡在线播放 | 国产一级视频在线 | 亚洲欭美日韩颜射在线 | 亚洲国产精品91 | 国产午夜福利精品一区二区三区 | 亚洲v天堂v手机在线 | 免费黄色网页 | 久久久资源 | 丁香花婷婷 | 久久丫精品忘忧草西安产品 | 国产黄色片免费 | 国产成人三级在线 | 精品久久久无码中文字幕边打电话 | 无套中出极品少妇白浆 | 成人性生交大片xbxb | 女体拷问一区二区三区 | 亚洲色图网址 | 欧美顶级毛片在线播放 | 色播开心网 | 伊伊人成亚洲综合人网香 | 奇米四色在线观看 | 9i看片成人免费 | 特黄特色的大片观看免费视频 | 国产精品 亚洲一区二区三区 | 国产精品丝袜黑色高跟鞋v18 | 久久久久成人网站 | 国产看黄网站又黄又爽又色 | 学生粉嫩无套白浆第一次 | 中文字幕在线视频免费视频 | 亚洲精品久久久久中文字幕一区 | 午夜无码大尺度福利视频 | 老女人伦理中文字幕 | 在线观看免费播放av片 | 中文字幕日韩精品亚洲一区 | 欧美激情精品 | 图书馆的女友在线观看 | 成人99一区二区激情免费看 | 台湾佬成人中文网222vvv | 在线综合亚洲欧洲综合网站 | 777色视频 | 国产免费人成视频在线观看 | 日本五十熟hd丰满 | 强行糟蹋人妻hd中文字幕 | 亚洲元码| brazzers欧美极品少妇 | 中文字幕人妻丝袜美腿乱 | 国内精品久 | 人人爽人人片人人片av | 99热这里只有精品免费播放 | 中文字幕日韩精品亚洲一区 | 怡春院久久国语视频免费 | 伊人成人在线视频 | 热精品 | 中文字幕日韩视频 | 久久精品香蕉视频 | 国产情侣呻吟对白高潮 | 国内自拍第二页 | 亚洲国产成人爱av在线播放 | 亚洲色最新高清av网站 | 欧美专区在线播放 | 暖暖成人免费视频 | 亚韩无码av电影在线观看 | 国产精品成熟老女人视频 | 国产激情美女久久久久久吹潮 | 香蕉av一区|