最近读过《高性能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)
}
+ 条件预加载
++ 在脚本加载期间提前检测,而不会等到函数被调用
分享到:
相关推荐
内容概要:本文详细介绍了LabVIEW控件的设计与实现,尤其是一些由经验丰富的老工程师精心打造的控件。LabVIEW是一款图形化编程语言,广泛应用于数据采集、仪器控制和工业自动化领域。文中通过具体实例展示了如何利用LabVIEW创建美观且功能强大的控件,如滑动条、波形图、金属质感旋钮、动态波形图表以及智能选项卡等。作者强调了LabVIEW控件在灵活性和美观度方面的优势,并分享了许多实用的技术细节和优化方法。 适合人群:具有一定编程基础并希望深入了解LabVIEW控件设计的开发者和技术爱好者。 使用场景及目标:适用于需要进行高效的数据展示和交互设计的应用场景,如工业控制系统、实验室设备操作界面等。目标是帮助用户掌握LabVIEW控件的高级特性,提高开发效率和用户体验。 其他说明:文章不仅提供了具体的代码示例,还探讨了控件美学背后的设计理念和技术实现,鼓励读者探索更多可能性。
Delphi 12.3控件之unidac_10.4.0_d27pro.exe
11.盛趣自闭面(还是自己太菜).txt
58面经面试过程和题目.txt
电大操作系统课后习题解答
人工智能技术与应用演讲【61页PPT】
chromedriver-mac-arm64-135.0.7049.41.zip
内容概要:本文详细介绍了QPSK(四相移键控)调制方法及其在瑞利信道和高斯白噪声信道下的误码率(BER)性能分析。首先展示了QPSK星座图的绘制方法,接着构建了一个简化的QPSK发射机模型,用于将二进制比特流映射到相应的星座点。随后,分别实现了两种信道模型:高斯白噪声信道(AWGN)和瑞利信道,并解释了它们的工作原理以及如何向传输信号添加噪声。文中还提供了详细的误码率测试脚本,通过大量随机比特进行仿真,最终得到了不同信噪比条件下的误码率曲线。此外,作者还讨论了QPSK与其他调制方式如BPSK、16QAM之间的性能差异,强调了频谱效率与抗噪能力之间的权衡关系。 适合人群:对无线通信系统感兴趣的科研人员、研究生以及从事通信工程领域的工程师。 使用场景及目标:①帮助读者理解QPSK的基本原理及其在不同信道环境中的行为特性;②提供实用的Python代码片段,便于快速搭建仿真环境并验证理论结果;③探讨各种调制方式的选择依据,指导实际应用中的优化决策。 其他说明:文中多次提到‘骚操作’,意指一些巧妙但非传统的编程技巧,有助于提高代码执行效率或简化复杂度。同时提醒读者注意仿真过程中可能出现的问题,如
新建 Microsoft Word 文档 (9).docx
计算机科学与技术- 软件开发工具 培训资料
bitcount统计每个元素中设置的位数 B = bitcount(A) Counts the number '1' bits in each element B = bitcount(A, bitValue) "bitValue" = 1 = default = counts the occurance of '1' if bitValue = 0; counts the number '0' The total bits to verify is [8,16,32,or 64] based on the maximal value of A B = bitcount(A, bitValue, maxBits) the total # of bits to examine
MOM生产运营管理平台解决方案【35页PPT】
deli-数码录音电话机-HCD6238(28)P-TSD-使用说明书
Java项目基于ssm框架的课程设计,包含LW+ppt
Delphi 12.3控件之Tsilang 7.5.0.0 D12.7z
ios+UIButton分类+UIButton+UIButton图片文字位置
项目已获导师指导并通过的高分毕业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行!可以放心下载
Java项目基于ssm框架的课程设计,包含LW+ppt
Delphi 12.3控件之TextEditorPro64.7z
尝试给OpenHarmony4.0增加可以在动态库中使用的日志模块 文章使用的资源,防止gitee资源丢失