前端程序员必须知道的高性能Javascript知识


Posted in Javascript onAugust 24, 2016

想必大家都知道,JavaScrip是全栈开发语言,浏览器,手机,服务器端都可以看到JS的身影。 本文会分享一些高效的JavaScript的最佳实践,提高大家对JS的底层和实现原理的理解。

数据存储
计算机学科中有一个经典问题是通过改变数据存储的位置来获得最佳的读写性能,在JavaScript中,数据存储的位置会对代码性能产生重大影响。 ? 能使用{}创建对象就不要使用new Object,能使用[]创建数组就不要使用new Array。JS中字面量的访问速度要高于对象。 ? 变量在作用域链中的位置越深,访问所需实践越长。对于这种变量,可以通过缓存使用局部变量保存起来,减少对作用域链访问次数 ? 使用点表示法(object.name)和操作符(object[name])操作并没有太多区别,只有Safari会有区别,点始终更快

循环
在JS中常见的循环有下面几种:

for(var i = 0; i < 10; i++) { // do something} 
for(var prop in object) { // for loop object}  
[1,2].forEach(function(value, index, array) { // 基于函数的循环})

毋庸质疑,第一种方式是原生的,性能消耗最低的,速度也最快。第二种方式for-in每次迭代都回产生更多的开销(局部变量),它的速度只有第一种 的1/7 第三种方式明显提供了更便利的循环方式,但是他的速度只有普通循环的1/8。所以可以根据自己项目情况,选择合适的循环方式。

事件委托
试想一下页面上每一个A标签添加一个事件,我们会不会给每一个标签都添加一个onClick呢。 当页面中存在大量元素都需要绑定同一个事件处理的时候,这种情况可能会影响性能。每绑定一个事件都加重了页面或者是运行期间的负担。对于一个富前端的应 用,交互重的页面上,过多的绑定会占用过多内存。 一个简单优雅的方式就是事件委托。它是基于事件的工作流:逐层捕获,到达目标,逐层冒泡。既然事件存在冒泡机制,那么我们可以通过给外层绑定事件,来处理 所有的子元素出发的事件。

document.getElementById('content').onclick = function(e) { 
  e = e || window.event;  
  var target = e.target || e.srcElement;  //如果不是 A标签,我就退出  
  if(target.nodeNmae !=== 'A') { return }  //打印A的链接地址  
  console.log(target.href) }

重绘与重排
浏览器下载完HTMl,CSS,JS后会生成两棵树:DOM树和渲染树。 当Dom的几何属性发生变化时,比如Dom的宽高,或者颜色,position,浏览器需要重新计算元素的几何属性,并且重新构建渲染树,这个过程称之为重绘重排。

bodystyle = document.body.style; 
bodystyle.color = red; 
bodystyle.height = 1000px; 
bodystyke.width = 100%;

上述方式修改三个属性,浏览器会进行三次重排重绘,在某些情况下,减少这种重排可以提高浏览器渲染性能。 推荐方式如下,只进行一次操作,完成三个步骤:

bodystyle = document.body.style; 
bodystyle.cssText 'color:red;height:1000px;width:100%';

JavaScript加载
IE8,Firefox3.5,Chrome2都允许必行下载JavaScript文件。所以<script>不会阻塞其他标签下载。 遗憾的是,JS下载过程依然会阻塞其他资源的下载,比如图片。尽管最新的浏览器通过允许并行下载提高了性能,但是脚本阻塞任然是一个问题。 因此,推荐将所有的<script>标签放在<body>标签的底部,以尽量减少对整个页面渲染的影响,避免用户看到一片空白

JS文件高性能部署
既然大家已经知道多个<script>标签会影响页面渲染速度,那么就不难理解“减少页面渲染所需的 HTTP”是网站提速的一条经典法则。 所以,在产品环境下合并所有的JS文件会减少请求数,从而加快页面渲染速度。 除了合并JS文件,我们还可以压缩JS文件。压缩是指将文件中与运行无关的部分进行剥离。剥离内容包括空白字符,和注释。改过程通常可以将文件大小减半。 还有一些压缩工具会将局部变量的长度减小,比如:

var myName = "foo" + "bar"; 
//压缩后变成 
var a = "foobar";

缓存JS文件
缓存HTTP组件能极大提高网站回访的用户体验。Web服务器通过“Expires HTTP响应头”来告诉客户端一个资源应该缓存多长时间。当然,缓存也有自己的缺陷: 当应用升级时,你需要确保用户下载到最新的静态内容。这个问题可以通过改变静态资源的文件名来解决。 你可能在产品环境看到浏览器引用jsapplication-20151123201212.js,这种就是以时间戳的方式保存新的JS文件,从而解决缓存不更新问题。

总结
当然,高效的JS不仅仅只有这些可以改进的地方,如果能够减少一些性能的损耗,我们就能更高效的使用JavaScript进行开发了。

Javascript 相关文章推荐
学习ExtJS Column布局
Oct 08 Javascript
javascript 在网页中的运用(asp.net)
Nov 23 Javascript
jquery之超简单的div显示和隐藏特效demo(分享)
Jul 09 Javascript
用C/C++来实现 Node.js 的模块(二)
Sep 24 Javascript
jQuery实现的背景动态变化导航菜单效果
Aug 24 Javascript
js+canvas简单绘制圆圈的方法
Jan 28 Javascript
AngularJS 限定$scope的范围实例详解
Jun 23 Javascript
React性能优化系列之减少props改变的实现方法
Jan 17 Javascript
echarts大屏字体自适应的方法步骤
Jul 12 Javascript
在Vue中实现随hash改变响应菜单高亮
Mar 09 Javascript
详细分析vue响应式原理
Jun 22 Javascript
js 图片懒加载的实现
Oct 21 Javascript
关于JavaScript数组你所不知道的3件事
Aug 24 #Javascript
详解Javascript ES6中的箭头函数(Arrow Functions)
Aug 24 #Javascript
手机端点击图片放大特效PhotoSwipe.js插件实现
Aug 24 #Javascript
jQuery Raty 一款不错的星级评分插件
Aug 24 #Javascript
jQuery实现自动输入email、时间和域名的方法
Aug 24 #Javascript
jQuery实现页面点击后退弹出提示框的方法
Aug 24 #Javascript
input 禁止输入特殊字符的四种实现方式
Aug 24 #Javascript
You might like
PHP5 操作MySQL数据库基础代码
2009/09/29 PHP
php定时计划任务与fsockopen持续进程实例
2014/05/23 PHP
浅析php单例模式
2014/11/25 PHP
php正则表达式获取内容所有链接
2015/07/24 PHP
转自Jquery官方 jQuery1.1.3发布,速度提升800%,体积保持20K
2007/08/19 Javascript
使用dynatrace-ajax跟踪JavaScript的性能
2010/04/12 Javascript
JS中的数组的sort方法使用示例
2014/01/22 Javascript
javascript实现二级级联菜单的简单制作
2015/11/19 Javascript
js仿QQ中对联系人向左滑动、滑出删除按钮的操作
2016/04/07 Javascript
JavaScript常用代码书写规范的超全面总结
2016/09/11 Javascript
js实现刷新页面后回到记录时滚动条的位置【两种方案可选】
2016/12/12 Javascript
jQuery获取table下某一行某一列的值实现代码
2017/04/07 jQuery
微信小程序调用PHP后台接口 解析纯html文本
2017/06/13 Javascript
基于JS递归函数细化认识及实用实例(推荐)
2017/08/07 Javascript
详解AngularJS1.x学习directive 中‘&amp; ’‘=’ ‘@’符号的区别使用
2017/08/23 Javascript
JS实现多选框的操作
2020/06/24 Javascript
python利用高阶函数实现剪枝函数
2018/03/20 Python
Django中的forms组件实例详解
2018/11/08 Python
Django的CVB实例详解
2020/02/10 Python
python+opencv3生成一个自定义纯色图教程
2020/02/19 Python
python内打印变量之%和f的实例
2020/02/19 Python
jupyter note 实现将数据保存为word
2020/04/14 Python
Jupyter notebook 远程配置及SSL加密教程
2020/04/14 Python
详解python3类型注释annotations实用案例
2021/01/20 Python
利用纯CSS3实现tab选项卡切换示例代码
2016/09/21 HTML / CSS
深入理解HTML的FormData对象
2016/05/17 HTML / CSS
HTML5 canvas基本绘图之填充样式实现
2016/06/27 HTML / CSS
夏威夷咖啡公司:Hawaii Coffee Company
2019/09/19 全球购物
Pandora德国官网:购买潘多拉手链、戒指、项链和耳环
2020/02/20 全球购物
婚庆公司的创业计划书
2014/01/22 职场文书
销售经理竞聘书
2014/03/31 职场文书
新闻发布会策划方案
2014/06/12 职场文书
改进作风怎么办发言材料
2014/08/17 职场文书
女方家长婚礼致辞
2015/07/27 职场文书
原型和原型链 prototype和proto的区别详情
2021/11/02 Javascript
Python Pandas 删除列操作
2022/03/16 Python