时间:2021-05-26
用于执行JavaScript和更新用户界面的进程通常被称为“浏览器UI线程”。JavaScript和用户界面更新在同一个进程中运行,因此一次只能处理一件事情。
·任何JavaScript任务都不应当执行超过100毫秒,过长的运行时间导致UI更新出现明显延迟,从而会影响用户体验。
·浏览器有两类限制JavaScript任务的运行时间的机制,调用栈大小限制(即记录自脚本开始以来执行的语句的数量)和长时间运行脚本限制(记录脚本执行的总时长,超时的时候会有弹框提示用户[chrome没有单独的程云霞脚本限制,替代做法是依赖其通用奔溃检测系统来处理此类问题])。
一些优化JavaScript任务时间的常见做法:
①使定时器让出时间片段
1.使用定时器处理数组。当处理过程不须同步,数据不须按顺序处理时。即可考虑用定时器分解任务。
如:
function processArray(items,process,callback){ var todo = items.concat(); setTimeout(function(){ process(todo.shift()); if(todo.length > 0){ setTimeout(arguments.callee,25); } else { callback(items); } },25);}var items = [1,2,3];function output(value){ console.log(value);} processArray(items,outputValue,function(){ console.log('finished output!')});②分割任务
如果一个函数的运行时间过长,那么可以把它拆分为一系列能在较短时间内完成的子函数。
如:
function multistep(steps,args,callback){ var tasks = steps.concat(); setTimeout(function(){ var task = tasks.shift(); task.apply(null,args||[]); if(tasks.length > 0){ setTimeout(arguments.callee,25); } else { callback(); } },25);}function saveDocument(id){ var tasks = [open,write,close]; multistep(tasks,[id],function(){ console.log('finished!'); })}③记录代码的运行时间
有时每次只执行一个任务的效率不高,且在两次之间产生25ms的延迟就更不好了。所以可以添加时间检测机制来改进processArray()方法。
如:
function timeProcessArray(items,process,callback){ var todo = items.concat(); setTimeout(function(){ var start = +new Date(); do{ process(todo.shift()); }while(todo.length > 0 &&(+new Date() - start < 50)) ; if(todo.length > 0){ setTimeout(arguments.callee,25); } else { callback(items); } },25);}注意,定时器虽然可以提高性能,但是过度使用会适得其反。需要控制web应用中的使用数量。
④使用Worker
Web Worker是新版浏览器支持的特性,它允许在UI线程外部执行JavaScript代码,从而避免锁定UI。
参考资料:http:///2015/11/deep-in-web-worker/
备注:
个人觉得,Worker的缺陷还是太多了。用不起来,而且要慎用。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前几天谈了正则匹配js字符串的问题:《js正则学习小记之匹配字符串》和《js正则学习小记之匹配字符串优化篇》。里面讲到了优化正则起到提升性能的问题,但是能提升多
Web前端性能优化教程01:减少Http请求性能黄金法则只有10%-20%的最终用户响应时间花在接收请求的HTML文档上,剩下的80%-90%时间花在HTML文
前言关于前端css性能优化,网上很多类似文章,我之前也写过,《网站前端性能优化之javascript和css》,感兴趣的可以去看下。今天我们旧事重提,再来谈谈c
现在来系统地学习一下Vue(参考vue.js官方文档):Vue.js是一个构建数据驱动的web界面的库,其目标是实现响应的数据绑定和组合的试图组件。Vue.js
散热。耐用性能上会表现的更为优异,虽然同等配置,但是价格略高,这种情况下还是选择品牌的电脑更为保险。笔记本电脑更纤薄机身,并且在性能上再次提升40%,使之响应更