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 相关文章推荐
js判断选择的时间是否大于今天的代码
Aug 20 Javascript
css+js实现部分区域高亮可编辑遮罩层
Mar 04 Javascript
解决jquery版本冲突的有效方法
Sep 02 Javascript
深入浅析Node.js 事件循环
Dec 20 Javascript
vue分页组件table-pagebar使用实例解析
Nov 15 Javascript
js中创建对象的几种方式
Feb 05 Javascript
JS实现发送短信验证后按钮倒计时功能(防止刷新倒计时失效)
Jul 07 Javascript
JavaScript中click和onclick本质区别与用法分析
Jun 07 Javascript
element-ui 设置菜单栏展开的方法
Aug 22 Javascript
node中使用log4js4.x版本记录日志的方法
Aug 20 Javascript
jquery实现简单拖拽效果
Jul 20 jQuery
vue实现日历表格(element-ui)
Sep 24 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
php数据库连接时容易出错的特殊符号问题
2010/09/01 PHP
PHP写杨辉三角实例代码
2011/07/17 PHP
PHP调试函数和日志记录函数分享
2015/01/31 PHP
详解WordPress中过滤链接与过滤SQL语句的方法
2015/12/18 PHP
Mac下php 5升级到php 7的步骤详解
2017/04/26 PHP
laravel 配置路由 api和web定义的路由的区别详解
2019/09/03 PHP
Laravel5.1 框架数据库操作DB运行原生SQL的方法分析
2020/01/07 PHP
很可爱的输入框
2008/08/03 Javascript
给Flash加一个超链接(推荐使用透明层)兼容主流浏览器
2013/06/09 Javascript
javaScript arguments 对象使用介绍
2013/10/18 Javascript
js的alert样式如何更改如背景颜色
2014/01/22 Javascript
JavaScript基本语法讲解
2015/06/03 Javascript
jQuery+HTML5实现图片上传前预览效果
2015/08/20 Javascript
jquery插件pagination实现无刷新ajax分页
2015/09/30 Javascript
探讨跨域请求资源的几种方式(总结)
2016/12/02 Javascript
如何用webpack4带你实现一个vue的打包的项目
2018/06/20 Javascript
angularJs select绑定的model取不到值的解决方法
2018/10/08 Javascript
Vue动态加载异步组件的方法
2018/11/21 Javascript
js的继承方法小结(prototype、call、apply)(推荐)
2019/04/17 Javascript
Vue实现滑动拼图验证码功能
2019/09/15 Javascript
JS回调函数深入理解
2019/10/16 Javascript
TensorFlow.js 微信小程序插件开始支持模型缓存的方法
2020/02/21 Javascript
[20:57]Ti4主赛事第三天开幕式
2014/07/21 DOTA
[59:00]DOTA2-DPC中国联赛 正赛 Ehome vs PSG.LGD BO3 第一场 3月7日
2021/03/11 DOTA
使用Python的Tornado框架实现一个简单的WebQQ机器人
2015/04/24 Python
Python聚类算法之凝聚层次聚类实例分析
2015/11/20 Python
python模块简介之有序字典(OrderedDict)
2016/12/01 Python
python使用matplotlib画饼状图
2018/09/25 Python
对Python中内置异常层次结构详解
2018/10/18 Python
Python实现FM算法解析
2019/06/18 Python
python中os包的用法
2020/06/01 Python
竞聘医务工作人员的自我评价分享
2013/11/04 职场文书
《高尔基和他的儿子》教学反思
2014/04/09 职场文书
青年志愿者活动方案
2014/08/17 职场文书
简历中的自我评价应该这样写!
2019/07/12 职场文书
mysql的单列多值存储实例详解
2022/04/05 MySQL