微信小程序基礎(chǔ)教程之worker線程的使用方法
前言
我們知道js是單線程的,在有時候需要處理一些密集計(jì)算或者是高延遲的時候,總會出現(xiàn)不便。而且,現(xiàn)在的cpu都是多核的,單線程也無法充分發(fā)揮電腦的計(jì)算能力。正是基于這種情況,才有了worker的誕生。由于微信小程序官方的教程比較看不懂...所以本篇主要介紹一下worker在小程序中的用法。
worker的一些說明
本篇主要是在小程序中使用worker,因?yàn)檎f明部分也是和小程序相關(guān)。
1、主線程和worker線程之間是通過消息來通信的,主線程不能直接調(diào)用worker線程中的函數(shù)
2、worker線程中不能使用使用wx系列的api。
步驟說明
小程序中,worker用法主要分為3步(按我個人的劃分),分別是:配置、主線程中創(chuàng)建調(diào)用和銷毀、worker線程中實(shí)現(xiàn)。
步驟一:配置
在app.json中配置worker目錄,如下圖(具體需要自己一一對應(yīng)目錄)
步驟二:主線程中創(chuàng)建調(diào)用和銷毀
這一步需要注意的就是,創(chuàng)建時填寫的是絕對路徑,其他基本沒什么問題。例如以下代碼,我們創(chuàng)建了worker線程,并向其發(fā)送了1個對象,對象中x=10和y=2。然后在接收到worker線程的消息時,打印出來。
// welcome.js onLoad: function (options) { const worker = wx.createWorker('/worker/myworker.js'); worker.postMessage({ x : 10, y : 2 }); worker.onMessage(function(res){ console.log('這是主線程打印的') console.log(res) }); },
worker線程中實(shí)現(xiàn)
worker中其實(shí)是默認(rèn)注入了一個叫worker的對象,直接調(diào)用監(jiān)聽消息和發(fā)送消息即可。如以下代碼:
// myworker.js worker.onMessage(function(res){ console.log('這是worker內(nèi)部線程打印的') console.log(res) let sum = add(res.x,res.y); worker.postMessage({ sum : sum }) }); function add(x,y){ return x+y; }
打印代碼如下圖:
小結(jié)
worker使用方法就是這樣了,一般來說密集計(jì)算和高延遲的代碼片段我們會放入其中,其他的話在主線程直接執(zhí)行就好了。
好的,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
你不知道的JS?ES6字符串標(biāo)簽函數(shù)分享
字符串標(biāo)簽函數(shù)是一種特殊的函數(shù)調(diào)用語法,本文將深入探討ES6中字符串標(biāo)簽函數(shù)的工作原理,并結(jié)合具體的代碼展示它的威力,快跟隨小編一起學(xué)習(xí)起來吧2023-06-06微信小程序在text文本實(shí)現(xiàn)多種字體樣式
這篇文章主要介紹了微信小程序在text文本實(shí)現(xiàn)多種字體樣式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-11-11js判斷手機(jī)號是否正確并返回的實(shí)現(xiàn)代碼
這篇文章主要介紹了js判斷手機(jī)號是否正確并返回的實(shí)現(xiàn)代碼,以及使用正則表達(dá)式判斷手機(jī)號是否正確,需要的的朋友參考下2017-01-01JS寫的數(shù)字拼圖小游戲代碼[學(xué)習(xí)參考]
昨天沒事做,就用JS寫了個數(shù)字拼圖的小游戲,自娛自樂。 可惜關(guān)于逆序數(shù)的問題還沒解決,現(xiàn)在有時是拼不成的,大家見諒了。2008-10-10通過JavaScript腳本復(fù)制網(wǎng)頁上的一個表格
通過JavaScript腳本復(fù)制網(wǎng)頁上的一個表格...2006-07-07