這篇文章主要講解了“分析Android微信小程序開(kāi)發(fā)的運(yùn)行機(jī)制”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“分析Android微信小程序開(kāi)發(fā)的運(yùn)行機(jī)制”吧!
焉耆ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書(shū)未來(lái)市場(chǎng)廣闊!成為成都創(chuàng)新互聯(lián)公司的ssl證書(shū)銷(xiāo)售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書(shū)合作)期待與您的合作!
01 我們稱(chēng)微信客戶端給小程序所提供的環(huán)境為宿主環(huán)境。小程序借助宿主環(huán)境提供的能力,可以完成許多普通網(wǎng)頁(yè)無(wú)法完成的功能。
02 渲染層與邏輯層
wxml,wxss工作在渲染層,JS 腳本工作在邏輯層。小程序的渲染層和邏輯層分別由2個(gè)線程管理:
渲染層的界面使用了WebView 進(jìn)行渲染;小程序一般會(huì)有多個(gè)頁(yè)面,所以渲染層存在多個(gè)WebView線程.
邏輯層采用JsCore線程運(yùn)行JS腳本。
線程間的通信由Native(微信客戶端)做中轉(zhuǎn).
03,程序與頁(yè)面
微信客戶端在打開(kāi)小程序之前,會(huì)把整個(gè)小程序的代碼包下載到本地。
緊接著通過(guò) app.json
的 pages
字段就可以知道你當(dāng)前小程序的所有頁(yè)面路徑:
{ "pages":[ "pages/index/index", --第一個(gè)頁(yè)面 "pages/logs/logs" ]}
小程序啟動(dòng)之后,在 app.js
定義的 App
實(shí)例的 onLaunch
回調(diào)會(huì)被執(zhí)行.
整個(gè)小程序只有一個(gè) App 實(shí)例,是全部頁(yè)面共享的
接下來(lái)我們簡(jiǎn)單看看小程序的一個(gè)頁(yè)面是怎么寫(xiě)的。
你可以觀察到 pages/logs/logs
下其實(shí)是包括了4種文件的,
logs.json,logs.wxml, logs.wxss, logs.js
微信客戶端會(huì)先根據(jù) logs.json
配置生成一個(gè)界面,頂部的顏色和文字你都可以在這個(gè) json
文件里邊定義好。緊接著客戶端就會(huì)裝載這個(gè)頁(yè)面的 WXML
結(jié)構(gòu)和 WXSS
樣式。最后客戶端會(huì)裝載 logs.js
,你可以看到 logs.js
的大體內(nèi)容就是:
Page({ data: { // 參與頁(yè)面渲染的數(shù)據(jù) logs: [] }, onLoad: function () { // 頁(yè)面渲染后 執(zhí)行 }})
Page
是一個(gè)頁(yè)面構(gòu)造器,這個(gè)構(gòu)造器就生成了一個(gè)頁(yè)面。在生成頁(yè)面的時(shí)候,小程序框架會(huì)把 data
數(shù)據(jù)和 index.wxml
一起渲染出最終的結(jié)構(gòu),于是就得到了你看到的小程序的樣子。
在渲染完界面之后,頁(yè)面實(shí)例就會(huì)收到一個(gè) onLoad
的回調(diào),你可以在這個(gè)回調(diào)處理你的邏輯。
04, 組件與API
小程序提供了豐富的組件,比如
為了讓開(kāi)發(fā)者可以很方便的調(diào)起微信提供的能力,例如獲取用戶信息、微信支付等等,小程序提供了很多 API 給開(kāi)發(fā)者去使用
需要注意的是:多數(shù) API 的回調(diào)都是異步,你需要處理好代碼邏輯的異步問(wèn)題。
比如,
要獲取用戶的地理位置時(shí),只需要:
wx.getLocation({ type: 'wgs84', success: (res) => { var latitude = res.latitude // 緯度 var longitude = res.longitude // 經(jīng)度 }})
調(diào)用微信掃一掃能力,只需要:
wx.scanCode({ success: (res) => { console.log(res) }})
感謝各位的閱讀,以上就是“分析Android微信小程序開(kāi)發(fā)的運(yùn)行機(jī)制”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)分析Android微信小程序開(kāi)發(fā)的運(yùn)行機(jī)制這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!