优化Javascript脚本以减少对浏览器UI线程的影响(定时器&webworker)

栏目: JavaScript · 发布时间: 5年前

内容简介:浏览器执行javascript的代码是单线程的,因此浏览器的UI线程不能同时处理UI界面的变化和javascript的代码执行。因为UI线程一次只能处理一个任务,所以有一个任务队列来存放即将要执行的任务。线程中当前任务执行完毕后,接着执行队列中的第一个任务。当一段javascript代码的执行时间大于假如要执行连续的三个耗时任务:

浏览器执行javascript的代码是单线程的,因此浏览器的UI线程不能同时处理UI界面的变化和javascript的代码执行。因为UI线程一次只能处理一个任务,所以有一个任务队列来存放即将要执行的任务。线程中当前任务执行完毕后,接着执行队列中的第一个任务。

使用定时器分解耗时量较大的脚本

当一段javascript代码的执行时间大于 100毫秒 ,就会对用户体验产生影响。因此最好将任务的执行时间控制在 50毫秒 以内。当需要循环大量数组或者执行一系列耗时任务时,可以使用定时器将任务分解。

假如要执行连续的三个耗时任务:

//封装多任务执行函数
function multipleTask(items,callback){
    var tasks = items.concat(),func;
    setTimeout(func = function(){
        if(tasks.length>0){
            var task = tasks.shift();
            task();
            setTimeout(func,25);
        }else{
            callback();
        }
    },25);
}
function step_1(){
    console.log('step_1 is runing.');
}
function step_2(){
    console.log('step_2 is runing.');
}
function step_3(){
    console.log('step_3 is runing.');
}
//调用执行
function run(){
    var items = [step_1,step_2,step_3];
    multipleTask(items,function(){
        console.log('multipleTask is over.');
    });
}
复制代码

假设要进行的一系列任务并不全是耗时长的,要避免两个耗时任务连续执行,又要避免短时耗的任务占用一次定时任务,需要做一些优化:

function timedMultipleTask(items,callback){
    var tasks = items.concat(),func;
    setTimeout(func = function(){
        var start = +new Date(),task;
        do{
            task = tasks.shift();
            task();
        }while(tasks.length>0&&new Date()-start>50)
        if(tasks.length>0){
            setTimeout(func,25);
        }else{
            callback();
        }
    },25);
}
复制代码

使用webworker处理脚本的大量计算

webworker是独立于UI线程的,每一个webworker都拥有自己的线程,不会影响到UI界面的变化。webworker拥有自己的运行环境,同时也能够和网页代码通过事件接口进行通信。webworker适合处理需要大量计算的场景,图像的计算,大数组的排序,解码/编码大字符串等。

假设需要重新 排序 一个大数组:

//web代码
var arr = [...];
var worker = new Worker('webworker.js');
worker.postMessage(arr);
worker.onmessage = function(event){
    var arr = event.data;
    process(data); //处理排完序的数组
}

//webworker代码
function arrSort(arr){
    var sortedArr = process(); //重新排序arr
    return sortedArr;
}
self.onmessage = function(event){
    var arr = event.data,
        sortedArr = arrSort(arr);
    self.postMessage(sortedArr);
}
复制代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

国际游戏设计全教程

国际游戏设计全教程

[美]迈克尔·萨蒙德 / 张然、赵嫣 / 中国青年出版社 / 2017-2 / 108.00元

你想成为一名电子游戏设计师吗?想知道《肯塔基0号路》《到家》《枪口》等独立游戏的制作理念及过程吗?想了解《戈莫布偶大冒险》《辐射3》《战争机器》中关卡设计的奥秘吗?本书用通俗易懂的文字介绍了在游戏开发与策划过程中,需要掌握的游戏设计原理和制作的基础知识,可以作为读者从“构思一个电子游戏”到“真正完成一个电子游戏”的完备指南。 本书以系统的游戏设计流程结合大量优秀的游戏设计案例进行讲解,让读者......一起来看看 《国际游戏设计全教程》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

SHA 加密
SHA 加密

SHA 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具