vue3中項目優(yōu)化方法詳解(Web?Worker的使用)
1.Web Worker的作用
本人的理解:js是單線程執(zhí)行代碼,也就是代碼需要從上往下執(zhí)行,而使用Web Worker后相當于分了一條線程出來執(zhí)行代碼,那么兩條線程肯定是比一條線程執(zhí)行的快。
2.新建Web Worker文件
在public文件夾下新建worker.js
說明:名稱可以隨意,worker.js相當于分裝了一個方法,只適用于某個功能或者數(shù)據(jù)處理,所以可以新建多個worker.js相當于分裝了多個用于不同場景的方法。
// worker.js
self.onmessage = function(event) {
const result = processData(event.data); // 執(zhí)行數(shù)據(jù)處理操作
console.log("result",result,event);
postMessage(result); // 將處理后的數(shù)據(jù)發(fā)送回主線程
};
// 執(zhí)行數(shù)據(jù)處理操作
function processData(data) {
// 在這里進行數(shù)據(jù)處理操作
let sum = 0;
for (let i = 0; i < 200000; i++) {
for (let i = 0; i < 10000; i++) {
sum += Math.random()
}
}
return '處理結果: ' + data +'/'+ sum;
}
3.引入使用
<template>
<div>
<button @click="processData">處理數(shù)據(jù)</button>
<div>{{ result }}</div>
</div>
</template>
<script setup>
import { ref } from "vue";
const result = ref('')
function processData() {
const worker = new Worker('/public/worker.js'); // 創(chuàng)建 Web Worker 參數(shù)為worker.js文件路徑
worker.onmessage = (event) => { // 監(jiān)聽Web Worker消息處理
result.value = event.data; // 處理返回的結果
};
worker.postMessage('哇酷哇酷'); // 發(fā)送消息給 Web Worker 參數(shù)為需要傳遞的數(shù)據(jù)
}
</script>4.效果

5.說明
(1).如果不使用Web Worker而直接在processData方法中使用以下代碼,那么要么卡死要么需要很久才能打印,而使用后就能相對較快打印出來
let sum = 0;
for (let i = 0; i < 200000; i++) {
for (let i = 0; i < 10000; i++) {
sum += Math.random()
}
}
console.log("sum",sum);
(2).Web Worker不需要安裝插件,如果使用worker-loader這個插件就需要安裝,該插件好像只能在webpack項目才能使用
總結
到此這篇關于vue3中項目優(yōu)化方法的文章就介紹到這了,更多相關vue3項目優(yōu)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
用VueJS寫一個Chrome瀏覽器插件的實現(xiàn)方法
這篇文章主要介紹了用VueJS寫一個Chrome瀏覽器插件的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02
關于element-ui中@selection-change執(zhí)行兩次的問題
這篇文章主要介紹了關于element-ui中@selection-change執(zhí)行兩次的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08

