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