当前位置: 首页 > news >正文

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

用于执行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的缺陷还是太多了。用不起来,而且要慎用。
 
 
 

转载于:https://www.cnblogs.com/LuckyWinty/p/6389149.html

相关文章:

  • 第二十一课、Qt中的标准对话框(下)------------------狄泰软件学院
  • 六种微服务架构的设计模式
  • 记录和保存日常文件的好处_无需整理
  • webpack 与 热编译webpack-dev-server
  • HDU1878 欧拉回路
  • 【整理】微信小程序开发须知
  • Unity Remote 5 使用
  • puppet自动化技术基础分析及实例部署详解
  • DSOframer的简单介绍和资源整理
  • swift开发多线程篇 - 多线程基础
  • 杭电2003——求绝对值
  • 《ArcGIS Runtime SDK for Android开发笔记》——(5)、基于Android Studio构建ArcGIS Android开发环境(离线部署)...
  • linux 性能篇 -- ps的用法
  • Linux命令篇之du命令和read命令
  • Skynet 小试Debug_console...
  • 4月23日世界读书日 网络营销论坛推荐《正在爆发的营销革命》
  • CSS选择器——伪元素选择器之处理父元素高度及外边距溢出
  • ECMAScript 6 学习之路 ( 四 ) String 字符串扩展
  • GitUp, 你不可错过的秀外慧中的git工具
  • Mac 鼠须管 Rime 输入法 安装五笔输入法 教程
  • mysql常用命令汇总
  • open-falcon 开发笔记(一):从零开始搭建虚拟服务器和监测环境
  • Quartz实现数据同步 | 从0开始构建SpringCloud微服务(3)
  • Spring Cloud Alibaba迁移指南(一):一行代码从 Hystrix 迁移到 Sentinel
  • 安卓应用性能调试和优化经验分享
  • 电商搜索引擎的架构设计和性能优化
  • 聊聊flink的BlobWriter
  • 前端自动化解决方案
  • 使用putty远程连接linux
  • 鱼骨图 - 如何绘制?
  • - 转 Ext2.0 form使用实例
  • 从如何停掉 Promise 链说起
  • 如何用纯 CSS 创作一个货车 loader
  • ​渐进式Web应用PWA的未来
  • # 数论-逆元
  • (javascript)再说document.body.scrollTop的使用问题
  • (Matalb回归预测)PSO-BP粒子群算法优化BP神经网络的多维回归预测
  • (Redis使用系列) Springboot 整合Redisson 实现分布式锁 七
  • (保姆级教程)Mysql中索引、触发器、存储过程、存储函数的概念、作用,以及如何使用索引、存储过程,代码操作演示
  • (附源码)apringboot计算机专业大学生就业指南 毕业设计061355
  • (附源码)计算机毕业设计SSM疫情社区管理系统
  • (接口封装)
  • (考研湖科大教书匠计算机网络)第一章概述-第五节1:计算机网络体系结构之分层思想和举例
  • (太强大了) - Linux 性能监控、测试、优化工具
  • (五)Python 垃圾回收机制
  • (原)Matlab的svmtrain和svmclassify
  • (转)AS3正则:元子符,元序列,标志,数量表达符
  • .NET Core 中插件式开发实现
  • .NET 发展历程
  • .NET开发不可不知、不可不用的辅助类(三)(报表导出---终结版)
  • .Net转前端开发-启航篇,如何定制博客园主题
  • [《百万宝贝》观后]To be or not to be?
  • [2017][note]基于空间交叉相位调制的两个连续波在few layer铋Bi中的全光switch——
  • [3D基础]理解计算机3D图形学中的坐标系变换
  • [Big Data - Kafka] kafka学习笔记:知识点整理