南通市崇川区北大青鸟计算机培训中心

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

2017-12-19 11:02  176次

  • 课程价格:请电话咨询
  • 开课时间:滚动开班
  • 上课地点:请咨询客服

如遇无效、虚假、诈骗课程,请立即举报为了您的资金安全,请见面交易,切勿提前支付任何费用举报

课程详情
这篇文章主要为大家详细介绍了前端程序员必须知道的高性能Javascript知识,更多IT技能以及高端技能解析尽在青鸟官网,感兴趣的小伙伴们可以参考一下。 想必大家都知道,JavaScrip是全栈开发语言,浏览器,手机,服务器端都可以看到JS的身影。本文会分享一些高效的JavaScript的*实践,提高大家对JS的底层和实现原理的理解。 数据存储 计算机*中有一个经典问题是通过改变数据存储的位置来获得*的读写性能,在JavaScript中,数据存储的位置会对代码性能产生重大影响。 – 能使用{}创建对象就不要使用new Object,能使用[]创建数组就不要使用new Array。JS中字面量的访问速度要高于对象。 – 变量在作用域链中的位置越深,访问所需实践越长。对于这种变量,可以通过缓存使用局部变量保存起来,减少对作用域链访问次数– 使用点表示法(object.name)和操作符(object[name])操作并没有太多区别,只有Safari会有区别,点始终更快 循环 在JS中常见的循环有下面几种: 毋庸质疑,*种方式是原生的,性能消耗*的,速度也最快。第二种方式for-in每次迭代都回产生更多的开销(局部变量),它的速度只有*种 的1/7 第三种方式明显提供了更便利的循环方式,但是他的速度只有普通循环的1/8。所以可以根据自己项目情况,选择合适的循环方式。 事件委托 试想一下页面上每一个A标签添加一个事件,我们会不会给每一个标签都添加一个onClick呢。 当页面中存在大量元素都需要绑定同一个事件处理的时候,这种情况可能会影响性能。每绑定一个事件都加重了页面或者是运行期间的负担。对于一个富前端的应用,交互重的页面上,过多的绑定会占用过多内存。 一个简单优雅的方式就是事件委托。它是基于事件的工作流:逐层捕获,到达目标,逐层冒泡。既然事件存在冒泡机制,那么我们可以通过给外层绑定事件,来处理所有的子元素出发的事件。 重绘与重排 浏览器下载完HTMl,CSS,JS后会生成两棵树:DOM树和渲染树。 当Dom的几何属性发生变化时,比如Dom的宽高,或者颜色,position,浏览器需要重新计算元素的几何属性,并且重新构建渲染树,这个过程称之为重绘重排。 上述方式修改三个属性,浏览器会进行三次重排重绘,在某些情况下,减少这种重排可以提高浏览器渲染性能。推荐方式如下,只进行一次操作,完成三个步骤: JavaScript加载 IE8,Firefox3.5,Chrome2都允许必行下载JavaScript文件。所以不会阻塞其他标签下载。遗憾的是,JS下载过程依然会阻塞其他资源的下载,比如图片。尽管*的浏览器通过允许并行下载提高了性能,但是脚本阻塞任然是一个问题。因此,推荐将所有的标签放在标签的底部,以尽量减少对整个页面渲染的影响,避免用户看到一片空白 JS文件高性能部署 既然大家已经知道多个标签会影响页面渲染速度,那么就不难理解“减少页面渲染所需的HTTP”是网站提速的一条经典法则。 所以,在产品环境下合并所有的JS文件会减少请求数,从而加快页面渲染速度。除了合并JS文件,我们还可以压缩JS文件。压缩是指将文件中与运行无关的部分进行剥离。剥离内容包括空白字符,和注释。改过程通常可以将文件大小减半。还有一些压缩工具会将局部变量的长度减小,比如: 缓存JS文件 缓存HTTP组件能极大提高网站回访的用户体验。Web服务器通过“Expires HTTP响应头”来告诉客户端一个资源应该缓存多长时间。当然,缓存也有自己的缺陷: 当应用升级时,你需要确保用户下载到*的静态内容。这个问题可以通过改变静态资源的文件名来解决。 总结 当然,高效的JS不仅仅只有这些可以改进的地方,如果能够减少一些性能的损耗,我们就能更高效的使用JavaScript进行开发了。 以上就是青鸟今天和大家分享的前端程序员必须知道的高性能Javascript知识啦!想要看更多实用的IT技巧可以来青鸟咨询哦!
相关课程
在线预约报名
  • 报名课程 :
    *端程序员必须知道的高性能Javascript知识
  • 报名学校 :
    南通市崇川区北大青鸟计算机培训中心
  • 学生姓名 :
    电话号码 :
    联系地址 :
    情况说明 :
    验  证  码 :