js 性能优化之快速响应的用户界面


Posted in Javascript onFebruary 15, 2017

用于执行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://www.alloyteam.com/2015/11/deep-in-web-worker/

备注:

个人觉得,Worker的缺陷还是太多了。用不起来,而且要慎用。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
一些有用的JavaScript和jQuery的片段分享
Aug 23 Javascript
node.js中的fs.closeSync方法使用说明
Dec 17 Javascript
jQuery实现表格行上移下移和置顶的方法
May 22 Javascript
JavaScript正则表达式匹配 div  style标签
Mar 15 Javascript
获取当前月(季度/年)的最后一天(set相关操作及应用)
Dec 27 Javascript
Jquery与Bootstrap实现后台管理页面增删改查功能示例
Jan 22 Javascript
Node.js如何响应Ajax的POST请求并且保存为JSON文件详解
Mar 10 Javascript
几种响应式文字详解
May 19 Javascript
JavaScript动态加载重复绑定问题
Apr 01 Javascript
vue-cli 默认路由再子路由选中下的选中状态问题及解决代码
Sep 06 Javascript
详解a标签添加onclick事件的几种方式
Mar 29 Javascript
详解ECMAScript2019/ES10新属性
Dec 06 Javascript
微信小程序  http请求封装详解及实例代码
Feb 15 #Javascript
DOM事件探秘篇
Feb 15 #Javascript
详解Angularjs 如何自定义Img的ng-load 事件
Feb 15 #Javascript
js实现滑动到页面底部自动加载更多功能
Feb 15 #Javascript
JS 实现随机验证码功能
Feb 15 #Javascript
JS实现PC手机端和嵌入式滑动拼图验证码三种效果
Feb 15 #Javascript
javascript设计模式之中介者模式学习笔记
Feb 15 #Javascript
You might like
全国FM电台频率大全 - 5 内蒙古自治区
2020/03/11 无线电
php smarty模版引擎中的缓存应用
2009/12/11 PHP
php从字符串创建函数的方法
2015/03/16 PHP
百度工程师讲PHP函数的实现原理及性能分析(二)
2015/05/13 PHP
详解PHP中的状态模式编程
2015/08/11 PHP
PHP面试题之文件目录操作
2015/10/15 PHP
php版微信公众号接口实现发红包的方法
2016/10/14 PHP
laravel实现上传图片的两种方式小结
2019/10/12 PHP
用htc组件制作windows选项卡
2007/01/13 Javascript
转一个日期输入控件,支持FF
2007/04/27 Javascript
通过判断JavaScript的版本实现执行不同的代码
2010/05/11 Javascript
关闭ie窗口清除Session的解决方法
2014/01/10 Javascript
javascript实现相同事件名称,不同命名空间的调用方法
2015/06/26 Javascript
jQuery中each()、find()和filter()等节点操作方法详解(推荐)
2016/05/25 Javascript
javascript小数精度丢失的完美解决方法
2016/05/31 Javascript
基于vue.js实现侧边菜单栏
2017/03/20 Javascript
js实现移动端轮播图效果
2020/12/09 Javascript
JS实现的将html转为pdf功能【基于浏览器端插件jsPDF】
2018/02/06 Javascript
webpack4.x下babel的安装、配置及使用详解
2019/03/07 Javascript
微信小程序--特定区域滚动到顶部时固定的方法
2019/04/28 Javascript
详解钉钉小程序组件之自定义模态框(弹窗封装实现)
2020/03/07 Javascript
[01:17:12]职来职往完美电竞专场
2014/09/18 DOTA
零基础写python爬虫之抓取百度贴吧代码分享
2014/11/06 Python
Python的Flask框架与数据库连接的教程
2015/04/20 Python
Python中import机制详解
2017/11/14 Python
Python冲顶大会 快来答题!
2018/01/17 Python
Python机器学习logistic回归代码解析
2018/01/17 Python
python模拟事件触发机制详解
2018/01/19 Python
python创建n行m列数组示例
2019/12/02 Python
解决TensorFlow训练模型及保存数量限制的问题
2021/03/03 Python
CSS3 please 跨浏览器的CSS3产生器
2010/03/14 HTML / CSS
香蕉共和国Banana Republic官网:美国GAP旗下偏贵族风格服饰品牌
2016/11/21 全球购物
生日寿宴答谢词
2014/01/19 职场文书
保护黄河倡议书
2014/05/16 职场文书
业务员年终工作总结2015
2015/05/28 职场文书
python实现简单聊天功能
2021/07/07 Python