vue3中項(xiàng)目?jī)?yōu)化方法詳解(Web?Worker的使用)
1.Web Worker的作用
本人的理解:js是單線程執(zhí)行代碼,也就是代碼需要從上往下執(zhí)行,而使用Web Worker后相當(dāng)于分了一條線程出來執(zhí)行代碼,那么兩條線程肯定是比一條線程執(zhí)行的快。
2.新建Web Worker文件
在public文件夾下新建worker.js
說明:名稱可以隨意,worker.js相當(dāng)于分裝了一個(gè)方法,只適用于某個(gè)功能或者數(shù)據(jù)處理,所以可以新建多個(gè)worker.js相當(dāng)于分裝了多個(gè)用于不同場(chǎng)景的方法。
// 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) {
// 在這里進(jìn)行數(shù)據(jù)處理操作
let sum = 0;
for (let i = 0; i < 200000; i++) {
for (let i = 0; i < 10000; i++) {
sum += Math.random()
}
}
return '處理結(jié)果: ' + 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; // 處理返回的結(jié)果
};
worker.postMessage('哇酷哇酷'); // 發(fā)送消息給 Web Worker 參數(shù)為需要傳遞的數(shù)據(jù)
}
</script>4.效果

5.說明
(1).如果不使用Web Worker而直接在processData方法中使用以下代碼,那么要么卡死要么需要很久才能打印,而使用后就能相對(duì)較快打印出來
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這個(gè)插件就需要安裝,該插件好像只能在webpack項(xiàng)目才能使用
總結(jié)
到此這篇關(guān)于vue3中項(xiàng)目?jī)?yōu)化方法的文章就介紹到這了,更多相關(guān)vue3項(xiàng)目?jī)?yōu)化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實(shí)現(xiàn)點(diǎn)擊追加選中樣式效果
今天小編就為大家分享一篇vue實(shí)現(xiàn)點(diǎn)擊追加選中樣式效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-11-11
用VueJS寫一個(gè)Chrome瀏覽器插件的實(shí)現(xiàn)方法
這篇文章主要介紹了用VueJS寫一個(gè)Chrome瀏覽器插件的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-02-02
關(guān)于element-ui中@selection-change執(zhí)行兩次的問題
這篇文章主要介紹了關(guān)于element-ui中@selection-change執(zhí)行兩次的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
Vue中引用JSON數(shù)據(jù)的方法小結(jié)
在現(xiàn)代Web開發(fā)中,JSON是一種輕量級(jí)的數(shù)據(jù)交換格式,易于人閱讀和編寫,同時(shí)也易于機(jī)器解析和生成,Vue.js作為一個(gè)流行的前端框架,支持多種方式引入和處理JSON數(shù)據(jù),本文將詳細(xì)介紹幾種在Vue中引用JSON數(shù)據(jù)的方法,需要的朋友可以參考下2024-10-10
解決運(yùn)行vue項(xiàng)目?jī)?nèi)存溢出問題
這篇文章主要介紹了解決運(yùn)行vue項(xiàng)目?jī)?nèi)存溢出問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04

