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 相关文章推荐
通过Jscript中@cc_on 语句识别IE浏览器及版本的代码
May 07 Javascript
限制textbox或textarea输入字符长度的JS代码
Oct 16 Javascript
jQuery替换textarea中换行的方法
Jun 10 Javascript
js 获取经纬度的实现方法
Jun 20 Javascript
javascript时间差插件分享
Jul 18 Javascript
在iframe中使bootstrap的模态框在父页面弹出问题
Aug 07 Javascript
Node.js+jade抓取博客所有文章生成静态html文件的实例
Sep 19 Javascript
javascript基于牛顿迭代法实现求浮点数的平方根【递归原理】
Sep 28 Javascript
jQuery实现动态加载select下拉列表项功能示例
May 31 jQuery
解决vue中修改export default中脚本报一大堆错的问题
Aug 27 Javascript
JavaScript数组类型Array相关的属性与方法详解
Sep 08 Javascript
vue 数字翻牌器动态加载数据
Apr 20 Vue.js
微信小程序  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创建多级目录代码
2008/06/05 PHP
php array的学习笔记
2012/05/16 PHP
php使用Imagick生成图片的方法
2015/07/31 PHP
PHP完全二叉树定义与实现方法示例
2017/10/09 PHP
js innerHTML 的一些问题的解决方法
2008/06/22 Javascript
说说JSON和JSONP 也许你会豁然开朗
2012/09/02 Javascript
Jquery实现鼠标移上弹出提示框、移出消失思路及代码
2013/05/19 Javascript
easyui window refresh 刷新两次的解决方法(推荐)
2016/05/18 Javascript
聊一聊JS中this的指向问题
2016/06/17 Javascript
jQuery快速高效制作网页交互特效
2017/02/24 Javascript
Vue之Watcher源码解析(1)
2017/07/19 Javascript
Vue2.0利用vue-resource上传文件到七牛的实例代码
2017/07/28 Javascript
vue-cli的eslint相关用法
2017/09/29 Javascript
使用Vuex实现一个笔记应用的方法
2018/03/13 Javascript
vuejs实现折叠面板展开收缩动画效果
2018/09/06 Javascript
js canvas实现写字动画效果
2018/11/30 Javascript
百度小程序自定义通用toast组件
2019/07/17 Javascript
layui问题之自动滚动二级iframe页面到指定位置的方法
2019/09/18 Javascript
解决layui富文本编辑器图片上传无法回显的问题
2019/09/18 Javascript
Vue跨域请求问题解决方案过程解析
2020/08/07 Javascript
解决antd 下拉框 input [defaultValue] 的值的问题
2020/10/31 Javascript
[02:56]DOTA2英雄基础教程 巨魔战将
2013/12/10 DOTA
解决Python2.7中IDLE启动没有反应的问题
2018/11/30 Python
python去重,一个由dict组成的list的去重示例
2019/01/21 Python
使用Python Pandas处理亿级数据的方法
2019/06/24 Python
flask框架配置mysql数据库操作详解
2019/11/29 Python
Python线程协作threading.Condition实现过程解析
2020/03/12 Python
Jupyter 无法下载文件夹如何实现曲线救国
2020/04/22 Python
CSS3实现滚动条动画效果代码分享
2016/08/03 HTML / CSS
加拿大大码女装购物网站:Penningtons
2020/12/26 全球购物
初级软件工程师面试题 Junior Software Engineer Interview
2015/02/15 面试题
医学生临床实习自我评价
2014/03/07 职场文书
检察机关个人对照检查材料
2014/09/15 职场文书
音乐教育专业自荐信
2014/09/18 职场文书
遗失证明范文
2015/06/19 职场文书
2015年政教主任工作总结
2015/07/23 职场文书