這篇文章主要介紹了微信小程序中devtool源碼分析的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇微信小程序中devtool源碼分析文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。
創(chuàng)新互聯(lián)建站成都網(wǎng)站建設(shè)按需設(shè)計(jì)網(wǎng)站,是成都網(wǎng)站設(shè)計(jì)公司,為酒樓設(shè)計(jì)提供網(wǎng)站建設(shè)服務(wù),有成熟的網(wǎng)站定制合作流程,提供網(wǎng)站定制設(shè)計(jì)服務(wù):原型圖制作、網(wǎng)站創(chuàng)意設(shè)計(jì)、前端HTML5制作、后臺(tái)程序開(kāi)發(fā)等。成都網(wǎng)站營(yíng)銷推廣熱線:18982081108
看看devtool的源碼有什么
第一步是找到小程序devtool的源碼,以mac系統(tǒng)為例,源碼的打開(kāi)方式如下圖:
其他的文件不用理會(huì),我們要研究的主要代碼在Content/Resources/app.nw/dist
目錄下,這個(gè)目錄包括devtool的功能代碼以及對(duì)小程序進(jìn)行執(zhí)行、編譯、打包、上傳等功能的代碼。當(dāng)然,這些代碼都是經(jīng)過(guò)混淆的,讀起來(lái)還挺費(fèi)勁(攤手~
需要著重注意的是Content/Resources/app.nw/dist/weapp
目錄,以及commit和trans兩個(gè)子目錄:
從文件的命名上大致可以猜到每個(gè)文件對(duì)應(yīng)的功能:
trans目錄下的文件負(fù)責(zé)將小程序源碼進(jìn)行一系列的轉(zhuǎn)換,最終被轉(zhuǎn)換為瀏覽器可識(shí)別的html、css以及js;
commit目錄下的文件負(fù)責(zé)執(zhí)行小程序的構(gòu)建、打包、上傳等功能。
既然我們知道小程序會(huì)進(jìn)行構(gòu)建打包流程,想得知小程序運(yùn)行機(jī)制最好的辦法就是研究構(gòu)建完畢之后的代碼。有了這個(gè)目標(biāo)之后,下一步就是查看devtool的日志獲取小程序構(gòu)建之后的代碼存放位置。
找到日志文件
Content/Resources/app.nw/dist/common/log/log.js
是負(fù)責(zé)管理devtool日志功能的文件,其中有這樣一段代碼:
const a = require('fs'), b = require('log'), c = require('path'), d = require('../../config/dirConfig.js'), e = d.WeappLog;
其中e
便是日志文件的存放目錄,然后我們追溯到config/dirConfig.js
中發(fā)現(xiàn)目錄路徑是由nw.App.getDataPath()
生成的,這個(gè)函數(shù)是node-webkit提供的API,生成結(jié)果的規(guī)則在不同的操作系統(tǒng)下有差異,可惜筆者并沒(méi)有找到相關(guān)的說(shuō)明(沮喪)。
但是此次代碼的探索并非沒(méi)有收獲,起碼我們知道了日志文件存放的目錄名為“WeappLog”,我們可以使用強(qiáng)大的命令行從硬盤中搜索此目錄:
mdfind WeappLog
大家可以參考這篇文章了解
mdfind
命令的用法
從輸出結(jié)果可以得知日志文件在Mac系統(tǒng)的存放目錄為/Users/<用戶名>/Library/Application Support/微信web開(kāi)發(fā)者工具/WeappLog
。進(jìn)入目錄后就會(huì)發(fā)現(xiàn)很多以.log
為后綴的日志文件:
上傳小程序的流程打包后的小程序在哪里
找到日志文件后便可以從devtool的執(zhí)行日志中獲取小程序被構(gòu)建后的代碼存放位置。當(dāng)然,第一步是要講小程序進(jìn)行構(gòu)建,操作方法是在小程序開(kāi)發(fā)工具的“項(xiàng)目”菜單”中點(diǎn)擊”預(yù)覽“:
成功后再日志文件中會(huì)出現(xiàn)這么一行記錄:
[Wed Jan 18 2017 15:20:24 GMT+0800 (CST)] INFO pack.js create /Users/ <用戶名>/Library/Application Support/微信web開(kāi)發(fā)者工具/Weappdest/1484724024071.wx success!
/Users/<用戶名>/Library/Application Support/微信web開(kāi)發(fā)者工具/Weappdest/1484724024071.wx
就是構(gòu)建完成的小程序代碼!趕緊去看看!
興致勃勃的找到/Users/<用戶名>/Library/Application Support/微信web開(kāi)發(fā)者工具/Weappdest/
目錄,然后發(fā)現(xiàn):空空如也!
看來(lái)微信團(tuán)隊(duì)還是很謹(jǐn)慎的,在將小程序源碼上傳之后便會(huì)刪除構(gòu)建產(chǎn)出的文件。但是這點(diǎn)小伎倆難不倒程序員!任何行為都是程序執(zhí)行的,我們直接修改相關(guān)的程序代碼就可以了嘛!
做點(diǎn)小手腳,看看打包后的代碼
在Content/Resources/app.nw/dist/weapp/commit/upload.js
中有一段這樣的代碼:
const a = require('fs'), j = require('rmdir'); //省略無(wú)關(guān)代碼 _exports.uploadForTest = (l, m, n) => { //省略無(wú)關(guān)代碼 c(l, { noCompile: !0 }, (s, t) => { if (s) return void n(s.toString()); let u = d.join(k, `${+new Date}.wx`); b(t, u, (v, w) => { j(t, (A, B, C) => {}); //省略無(wú)關(guān)代碼 if (y > q) return a.unlink(u, () => {}), void n(`代碼包大小為 ${y} kb,超出限制 ${y-q} kb,請(qǐng)刪除文件后重試`); //省略無(wú)關(guān)代碼 })
上述代碼省略了一些與我們當(dāng)前討論內(nèi)容無(wú)關(guān)的代碼,感興趣的讀者可以自行研究。
上述代碼有兩個(gè)刪除文件的行為:
rmdir
:刪除構(gòu)建完成但是并未打包的代碼目錄;
fs.unlink
:刪除打包完成的文件。
將執(zhí)行刪除的代碼注釋以后,再通過(guò)小程序開(kāi)發(fā)者工具進(jìn)行預(yù)覽上傳操作后,在上文中我們得到的目錄中便會(huì)留下構(gòu)建以及打包后的文件了。如下:
其中以.wx
為后綴的文件是經(jīng)過(guò)打包后的文件,也就是上傳到微信服務(wù)器的文件。其同名的目錄文件夾是構(gòu)建完成且打包之前的源文件。
以config.js
為例,構(gòu)建后的代碼如下:
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); exports.default = { basePath: 'https://djtest.cn', fileBasePath: 'https://djtest.cn' };
其實(shí)僅僅將ES6的語(yǔ)法轉(zhuǎn)譯成了ES5語(yǔ)法。其余的wxml、wxss以及js文件基本也是這樣的狀態(tài),所以可以推斷源碼上傳至微信服務(wù)器后會(huì)執(zhí)行真正的構(gòu)建動(dòng)作,開(kāi)發(fā)工具只執(zhí)行了一些簡(jiǎn)單地構(gòu)建行為。
關(guān)于“微信小程序中devtool源碼分析”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“微信小程序中devtool源碼分析”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。