W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
Web Worker 允許你在后臺線程中運行 CPU 密集型計算,解放主線程以更新用戶界面。如果你發(fā)現(xiàn)你的應(yīng)用會進行很多計算,比如生成 CAD 圖紙或進行繁重的幾何計算,那么使用 Web Worker 可以幫助你提高應(yīng)用的性能。
CLI 不支持在 Web Worker 中運行 Angular。
要把 Web Worker 添加到現(xiàn)有項目中,請使用 Angular CLI ?ng generate
? 命令。
ng generate web-worker <location>
你可以在應(yīng)用的任何位置添加 Web Worker。比如,要把一個 Web Worker 添加到根組件 ?src/app/app.component.ts
?,請運行如下命令。
ng generate web-worker app
該命令會執(zhí)行以下操作。
src/app/app.worker.ts
? 以接收消息。addEventListener('message', ({ data }) => {
const response = `worker response to ${data}`;
postMessage(response);
});
src/app/app.component.ts
? 以使用這個 Worker。if (typeof Worker !== 'undefined') {
// Create a new
const worker = new Worker(new URL('./app.worker', import.meta.url));
worker.onmessage = ({ data }) => {
console.log(`page got message: ${data}`);
};
worker.postMessage('hello');
} else {
// Web workers are not supported in this environment.
// You should add a fallback so that your program still executes correctly.
}
生成這個初始腳手架之后,你必須把代碼重構(gòu)成向這個 Worker 發(fā)送消息和從 Worker 接收消息,以便使用 Web Worker。
某些環(huán)境或平臺(比如服務(wù)端渲染中使用的 ?
@angular/platform-server
? 不支持 Web Worker。為了確保你的應(yīng)用能夠在這些環(huán)境中工作,你必須提供一個回退機制來執(zhí)行本來要由這個 Worker 執(zhí)行的計算。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: