最近读过《高性能javascript》,记录如下:
PS: 没有什么JS代码会重要到可以影响用户体验的程度
1. 由于浏览器在执行js代码时,会阻塞其他资源的下载
2. 无阻塞的脚本
* 延迟的脚本(defer)
+ 并不是理想的跨浏览器解决方案
* 动态脚本元素
+ 通过动态创建script元素来获取脚本
* XHR脚本注入
+ 通过ajax请求获取js,然后动态创建script元素,并将responseText附加到script中
+ 不能跨域
PS:推荐学习开源组件LABjs(开源无阻塞脚本加载工具,可以管理不同脚本的依赖关系)
3. 数据访问相关问题
* 改变作用域链
** with和try+catch语句
** 使用with语句时,运行期山下文的作用域链临时被改变了。这时一个新的可变对象被创建,它包含了参数指定的对象的所有属性。这个对象被推入所用域链的头部,这意味着函数的所有局部变量现在处于第二个所用域链对象中。因此访问代价变得更高。
** try catch语句具有同样的问题,不过它是非常有用的语句,不建议完全避免。
* 缓存对象成员
* 访问直接量和局部变量的速度最快,相反,访问数组元素和对象成员相对较慢
* 嵌套的对象成员会明显影响性能,尽量少用
* 属性或者方法在原型链中的位置越深,访问它的速度越慢
4. dom编程
* HTML集合一直与文档保持着连接,每次需要最新信息时,都会重复执行查询的过程,哪怕是获取集合里的元素个数
* 遍历dom树中节点时,推荐使用nextSibling(IE6、7十分推荐)
* 最小化dom访问次数
* 小心处理HTML文档集合,因为它实时连系着底层文档
* 如果可以的话,使用更快的API(比如:querySelectorAll, firstElementChild)
* 留意重绘和重排;批量修改样式时,“离线”操作dom树,使用缓存,并减少访问布局信息的次数
PS: 有关重绘和重排请参考:
* 使用事件委托来减少时间处理器的数量(主要利用冒泡原理)
5. 算法和流程控制
* for in 循环的每次迭代都会产生更多开销(建议不要使用for in遍历数组成员)
* js引擎支持的递归数量与js调用堆栈大小直接相关,只有ie例外,它的调用栈于系统空闲内存有关
* 使用Memoization方法避免重复工作(缓存计算数据)
6. 正则表达式(待继续学习)
7. 快速响应的用户界面
* 浏览器限制了js任务的运行时间
* 单个js操作花费的总时间不应该超过100ms(超过100ms意味着用户会感到自己与界面失去联系)
* 使用定时器让出时间片段,定时器建议时间最小25ms(windows系统中定时器分辨率为15ms)(详细信息请参考:http://hi.baidu.com/chyong168/blog/item/330b6f07392d8c60020881bc.html)
* 尝试HTML5中的Web Workers API
** 可以使得代码运行且不占用浏览器UI线程的东西
** 每个新的worker都在自己的线程中运行代码
8. Ajax
* 数据格式
** xml
** json
** json-p
** html
** 自定义格式
* Ajax性能指南
** 缓存数据
*** 设置http头
*** 本地存储
9. 编程实践
* 避免双重求值
** eval、Function
** setTimeout和setInterval建议传入函数而不是字符串来作为第一个参数
** 不要重复工作(不要做已经完成的工作)
*** 示例:addHandler
function addHandler(target, eventType, handler) {
if(target.addEventListener) {
target.addEventListener(eventType, handler, false);
}
else {
target.attachEvent("on" + eventType, handler);
}
}
上述代码对做了不同浏览器的兼容,看似充分优化,隐藏的性能问题在于每次函数调用时都做了重复工作。每次检查过程都相同:看看置顶方法是否存在,用户不可能在页面加载完成后奇迹般得改变浏览器,那么这次检查就是重复的。
*** 解决方案:
+ 延迟加载
function addHandler(target, eventType, handler) {
//重写现有函数
if(target.addEventListener) {
addHandler = function(target, eventType, handler) {
target.addEventListener(eventType, handler, false);
}
}
else {
addHandler = function(target, eventType, handler) {
target.attachEvent("on" + eventType, handler);
}
}
//调用新函数
addHandler(target, eventType, handler)
}
+ 条件预加载
++ 在脚本加载期间提前检测,而不会等到函数被调用
分享到:
相关推荐
4. 学习性能优化的最新趋势:随着技术的发展,不断有新的优化技术和工具出现,需要及时学习和跟进。 作为腾讯的Web前端高级工程师,对性能优化有着丰富经验,以下是一些具体的优化技巧: - 精简代码:去除无效和...
郭碧青是腾讯公司的一位资深前端工程师,他在Web前端性能优化方面有着丰富的实践经验,并且对于性能优化的工作充满热情。郭碧青在行业内的知名度很高,虽然行事低调,但是经常受邀在各种大型会议和技术活动中分享...
在这些应用中,Web 站点的性能要求非常高,因此需要进行 Web 前端性能优化。 知识点九: Web 前端性能优化的研究现状 Web 前端性能优化的研究现状还远远不够,特别是在国内的情况下。大多数站点并不关注 Web 前台的...
### Web前端性能优化知识点 #### 一、构建优化 **1.1 文件压缩与合并** - **文件压缩**:利用工具如UglifyJS、Terser等对JavaScript、CSS等静态资源进行压缩,减少文件体积,从而加快加载速度。 - **文件合并**:...
在IT行业的领域内,"web前端性能测试"是一项至关重要的技术环节,它直接影响着用户的体验质量和网站的整体性能表现。从给定的文件信息来看,我们可以深入探讨以下几点关键知识点: ### 1. 前端性能测试的目的 前端...
"Vue.js"是一个轻量级的JavaScript框架,以其易学易用、高性能和灵活性著称,常用于构建复杂的单页应用。"js"即JavaScript,是Web开发中的主要脚本语言,用于实现页面的动态效果和交互。 在农产品购物车项目中,...
#### 一、《高性能JavaScript》 **知识点概述:** 1. **性能优化基础知识:** - 了解JavaScript引擎的工作原理及其对性能的影响。 - 学习如何通过代码结构和组织来提高执行效率。 2. **DOM操作与优化:** - ...
而"前端开源库-web-worker-manager"就是这样一个专门用于管理和优化Web Worker使用的工具。 **Web Worker API介绍** Web Worker是HTML5的一个特性,它允许在浏览器后台独立于主线程执行脚本,避免了长时间运行的...
Google在Web前端性能优化方面也做出了许多贡献,包括Page Speed分析工具、Closure Compiler压缩工具、V8 JavaScript引擎的高性能执行、AngularJS框架以及后来的AngularJS2.0在性能上的改进,还有推动HTTP2协议的发展...
《高性能网站建设进阶指南》是一本专为WEB开发者设计的性能优化手册,...以上这些内容都是《高性能网站建设进阶指南》可能涵盖的知识点,通过学习和实践,WEB开发者可以更好地掌握性能优化技巧,提升网站的整体效能。
该Vue和TypeScript驱动的Web前端项目liu-m-y,总计包含606个文件,其中包含241个JavaScript文件、91个Vue组件文件、87个PNG图像文件、40个CSS样式文件、25个GIF动画文件、24个HTML模板文件、19个TypeScript文件、11...
在现代Web开发中,前端开源库扮演着至关重要的角色,它们提供了一系列的工具和功能,帮助开发者构建高效、可维护的Web应用。...对于希望提供高性能、跨平台的Web应用的开发者来说,这个开源库是一个不可或缺的助手。
正如标题"Web前端性能分析工具导引"所暗示的,关注这一领域的核心在于优化用户对页面加载速度和响应时间的感知。根据Yahoo的高性能网页最佳实践,前端性能优化能够显著提升网站的性能,减少用户流失,提高销售转化率...
6. "Web前端开发应用-03.ppt":由于其位置在中间但未按顺序出现,它可能涵盖了一些特殊主题,如浏览器兼容性问题、性能优化技巧,或者介绍一个特定的框架或库,如React、Vue或Angular。 总的来说,这一系列的PPT...
"前端性能优化知识点总结" 前端性能优化是非常重要的一方面,好的性能优化可以提高网站的用户体验,而坏的性能优化则可能会带来麻烦和规则太多的问题。在这个知识点总结中,我们将介绍八个方面的前端性能优化知识点...
【标题】"web前端工程师-.rar"所涉及的知识点涵盖了前端开发领域的多个方面,这是一个针对Web前端工程师的综合学习资源。在Web前端开发中,主要关注的是如何在浏览器环境中实现用户交互、页面展示以及数据通信等功能...
"前端开源库-smooth-fe" 是一个专注于前端性能优化的开源项目,它的主要目标是提供一套解决方案,使得CSS和JavaScript的加载与执行更加平滑、高效。在现代Web开发中,用户体验是至关重要的,而页面的加载速度和交互...
本文将深入探讨标题和描述中提及的两本书籍《JavaScript语言精粹》和《高性能JavaScript》所涵盖的知识点。 首先,我们来关注《JavaScript语言精粹》。这本书主要侧重于JavaScript的核心概念和最佳实践,旨在帮助...