微信小程序開發(fā)多線程處理機制worker
不少從事搭建崗的技術(shù)人員都了解過多線程問題,多線程是指從系統(tǒng)或者硬件上實現(xiàn)多個線程并發(fā)執(zhí)行的技術(shù)。具有多線程能力的計算機因有硬件支持而能夠在同一時間執(zhí)行多于一個線程,進而提升整體處理性能。在微信小程序中也可能有線程并發(fā)執(zhí)行的階段,這時候worker可以處理開發(fā)小程序的多線程機制。
微信小程序的一些異步處理任務(wù)可放置worker中運行,原理是調(diào)用worker執(zhí)行多條并行線程,待結(jié)果返回到微信小程序的主線程。當操作worker時,主線程數(shù)據(jù)被復制并通過 Worker.Message()來傳輸,其中 Worker.postMessage()是發(fā)送數(shù)據(jù)函數(shù),Worker.onMessage()則是接收。
操作worker首先要配置worker信息,在app.js中聲明worker放置目錄,目錄下的代碼將被打包成一個文件:
{
workers: workers
}
接著在worker中添加文件,添加一個請求文件夾request和一個相應(yīng)文件夾response。
workers/request/index.js
workers/request/utils.js
workers/response/index.js
添加后,目錄結(jié)構(gòu)如下:
├── app.js
├── app.json
├── project.config.json
└── workers
├── request
│ ├── index.js
│ └── utils.js
└── response
└── index.js
下一步編寫 Worker 代碼
在workers/request/index.js編寫 Worker 響應(yīng)代碼
var utils = require(\'./utils\')
// 在 Worker 線程執(zhí)行上下文會全局設(shè)立一個 `worker` 對象,直接調(diào)用
worker.onMeesage/postMessage 即可
worker.onMessage(function (res) {
console.log(res)
})
接著在主線程中初始化Worker
在主線程的代碼 app.js 中聲明 Worker
var worker = wx.createWorker(\'workers/request/index.js\') // 文件名指定 worker
的入口文件路徑,絕對路徑
最后主線程向Worker發(fā)出數(shù)據(jù)接收請求
worker.postMessage({
msg: \'hello worker\'
})
操作worker注意事項:
Workers 之間不支持發(fā)送消息。
Worker 的入??谖募?wx.createWorker() 時指定,搭建者可動態(tài)指定 Worker 入口文件
Worker 內(nèi)代碼只能 require 指定 Worker 路徑內(nèi)的文件,無法引用其它路徑。
Worker 最大并發(fā)數(shù)量束縛為 1 個,設(shè)立下一個前請用 Worker.terminate() 結(jié)束當前 Worker。
Worker 內(nèi)不支持 wx 系列的 API。
推薦閱讀:微信小程序前端搭建群功能教材 微信小程序搭建教材