溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

分析Android微信小程序開發(fā)的運(yùn)行機(jī)制

發(fā)布時(shí)間:2021-11-05 16:41:29 來源:億速云 閱讀:156 作者:iii 欄目:web開發(fā)

這篇文章主要講解了“分析Android微信小程序開發(fā)的運(yùn)行機(jī)制”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“分析Android微信小程序開發(fā)的運(yùn)行機(jī)制”吧!

01 我們稱微信客戶端給小程序所提供的環(huán)境為宿主環(huán)境。小程序借助宿主環(huán)境提供的能力,可以完成許多普通網(wǎng)頁無法完成的功能。

02 渲染層與邏輯層

wxml,wxss工作在渲染層,JS 腳本工作在邏輯層。小程序的渲染層和邏輯層分別由2個(gè)線程管理:

渲染層的界面使用了WebView 進(jìn)行渲染;小程序一般會(huì)有多個(gè)頁面,所以渲染層存在多個(gè)WebView線程.

邏輯層采用JsCore線程運(yùn)行JS腳本。

線程間的通信由Native(微信客戶端)做中轉(zhuǎn).

03,程序與頁面

微信客戶端在打開小程序之前,會(huì)把整個(gè)小程序的代碼包下載到本地。

緊接著通過 app.json 的 pages 字段就可以知道你當(dāng)前小程序的所有頁面路徑:

{
  "pages":[
    "pages/index/index", --第一個(gè)頁面
    "pages/logs/logs"
  ]}

小程序啟動(dòng)之后,在 app.js 定義的 App 實(shí)例的 onLaunch 回調(diào)會(huì)被執(zhí)行.

整個(gè)小程序只有一個(gè) App 實(shí)例,是全部頁面共享的

接下來我們簡(jiǎn)單看看小程序的一個(gè)頁面是怎么寫的。

你可以觀察到 pages/logs/logs 下其實(shí)是包括了4種文件的,

logs.json,logs.wxml, logs.wxss, logs.js

微信客戶端會(huì)先根據(jù) logs.json 配置生成一個(gè)界面,頂部的顏色和文字你都可以在這個(gè) json 文件里邊定義好。緊接著客戶端就會(huì)裝載這個(gè)頁面的 WXML 結(jié)構(gòu)和 WXSS 樣式。最后客戶端會(huì)裝載 logs.js,你可以看到 logs.js 的大體內(nèi)容就是:

Page({
  data: { // 參與頁面渲染的數(shù)據(jù)
    logs: []
  },
  onLoad: function () {
    // 頁面渲染后 執(zhí)行
  }})

Page 是一個(gè)頁面構(gòu)造器,這個(gè)構(gòu)造器就生成了一個(gè)頁面。在生成頁面的時(shí)候,小程序框架會(huì)把 data 數(shù)據(jù)和 index.wxml 一起渲染出最終的結(jié)構(gòu),于是就得到了你看到的小程序的樣子。

在渲染完界面之后,頁面實(shí)例就會(huì)收到一個(gè) onLoad 的回調(diào),你可以在這個(gè)回調(diào)處理你的邏輯。

04, 組件與API

小程序提供了豐富的組件,比如<map></map>

為了讓開發(fā)者可以很方便的調(diào)起微信提供的能力,例如獲取用戶信息、微信支付等等,小程序提供了很多 API 給開發(fā)者去使用

需要注意的是:多數(shù) API 的回調(diào)都是異步,你需要處理好代碼邏輯的異步問題。

比如,

要獲取用戶的地理位置時(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微信小程序開發(fā)的運(yùn)行機(jī)制”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)分析Android微信小程序開發(fā)的運(yùn)行機(jī)制這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI