這篇文章主要講解了“分析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ī)制”吧!

01 我們稱(chēng)微信客戶(hù)端給小程序所提供的環(huán)境為宿主環(huán)境。小程序借助宿主環(huán)境提供的能力,可以完成許多普通網(wǎng)頁(yè)無(wú)法完成的功能。
02 渲染層與邏輯層
wxml,wxss工作在渲染層,JS 腳本工作在邏輯層。小程序的渲染層和邏輯層分別由2個(gè)線(xiàn)程管理:
渲染層的界面使用了WebView 進(jìn)行渲染;小程序一般會(huì)有多個(gè)頁(yè)面,所以渲染層存在多個(gè)WebView線(xiàn)程.
邏輯層采用JsCore線(xiàn)程運(yùn)行JS腳本。
線(xiàn)程間的通信由Native(微信客戶(hù)端)做中轉(zhuǎn).
03,程序與頁(yè)面
微信客戶(hù)端在打開(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
微信客戶(hù)端會(huì)先根據(jù) logs.json 配置生成一個(gè)界面,頂部的顏色和文字你都可以在這個(gè) json 文件里邊定義好。緊接著客戶(hù)端就會(huì)裝載這個(gè)頁(yè)面的 WXML 結(jié)構(gòu)和 WXSS 樣式。最后客戶(hù)端會(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
小程序提供了豐富的組件,比如<map></map>
為了讓開(kāi)發(fā)者可以很方便的調(diào)起微信提供的能力,例如獲取用戶(hù)信息、微信支付等等,小程序提供了很多 API 給開(kāi)發(fā)者去使用
需要注意的是:多數(shù) API 的回調(diào)都是異步,你需要處理好代碼邏輯的異步問(wèn)題。
比如,
要獲取用戶(hù)的地理位置時(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)注!
網(wǎng)頁(yè)題目:分析Android微信小程序開(kāi)發(fā)的運(yùn)行機(jī)制-創(chuàng)新互聯(lián)
瀏覽地址:http://www.jbt999.com/article5/dihdoi.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、網(wǎng)站營(yíng)銷(xiāo)、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站導(dǎo)航、企業(yè)建站、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容