High Performance JavaScript(高性能JavaScript)读书笔记分析


Posted in Javascript onMay 05, 2011

第一章:加载和执行

浏览器的JavaScript的引擎是编译器层的优化;
当浏览器执行JavaScript代码时,不能同时做其他任何事情(单一进程),意味着<script>标签每次出现都霸道地让页面等带脚本的解析和执行(每个文件必须等到前一个文件下载并执行完成才会开始下载),所以头部的JS和CSS用来渲染页面,交互行为(几乎所有)的JS放在<body>底部;
主流浏览器都允许并行下载JS。
减少外链脚本数量将会改善性能(合并JS)
任何网站都可以使用一个把制定文件合并处理后的URL来获取任意数量的文件。
defer属性可延迟脚本(只有IE4 和FF3.5 支持)
第二章:数据访问

JavaScript中有四种基本的数据存取位置: 直接量,变量,数组元素(以数字作为索引),对象成员(以字符床作为索引)。
访问直接量和局部变量的速度最快,相反,访问数组元素和对象成员相对较慢。
属性或方法在原型链中的位置越深,访问它的速度也越慢。
通常来说,可以通过吧常用的对象,数组元素,跨越变量保存在局部变量中来改善JavaScript性能。
第三章:DOM编程

DOM操作在webkit内核的浏览器速度快,其他的浏览器innerHTML执行快。
访问和操作DOM是现代WEB应用的重要部分。但每次穿越链接ECMAScript和DOM两个岛屿之间的桥梁都会被收取‘过桥费'.
要留意重回和重排。
在IE中:hover会降低响应速度。
第四章:算法和流程控制

避免使用for-in循环,除非需要遍历一个属性数量位置的对象。
了解栈溢出错误。
第五章:字符串和正则表达式

回溯既是正则表达式匹配功能的基本组成部分,也是正则表达式的低效之源。
第六章:快速响应的用户界面

任何JavaScript任务都不应当执行超过100毫秒。
Web workers是新版浏览器支持的特性。
没有什么JavaScript代码会重要到可以影响用户体验的程度.
第七章:Ajax

JSON是轻量级的数据格式,解析速度快。
减少请求数,可通过合并JS和CSS,还有IMG。
缩短页面加载时间,页面主要内容加载完成后,用Ajax获取那些次要的文件。
第八章:编程实践

大多数的时候,没必要使用eval()和Function(),因此最好避免使用它们。至于setTimeout()和setInterval(),建议传入函数而不是字符串来作为第一个参数。
在JavaScript中创建对象和数组的方法有多种,但使用对象和数组直接量是最快的方式(对象属性和数组项越多,使用直接量的好处就越明显)。
不要重复工作:延迟加载;条件预加载.
多使用原生方法,因为更快。
第九章:构建并部署高性能JavaScript应用

PV(page view)即页面浏览量或点击量。
减少页面渲染所需的HTTP请求数,特别是针对那些首次访问网站的用户。
JavaScript压缩。
JavaScript缓存。
使用内容分发网络(CDN)
第十章主要介绍工具:如firebug,YSlow,和一些性能分析.

Javascript 相关文章推荐
JS时间选择器 兼容IE6,7,8,9
Jun 26 Javascript
js特效,页面下雪的小例子
Jun 17 Javascript
js替代copy(示例代码)
Nov 27 Javascript
分享一则javascript 调试技巧
Jan 02 Javascript
js实现的捐赠管理完整实例
Jan 20 Javascript
详解jQuery移动页面开发中的ui-grid网格布局使用
Dec 03 Javascript
etmvc+jQuery EasyUI+combobox多值操作实现角色授权实例
Nov 09 Javascript
Bootstrap风格的zTree右键菜单
Feb 17 Javascript
JS字符串长度判断,超出进行自动截取的实例(支持中文)
Mar 06 Javascript
JS完成画圆圈的小球
Mar 07 Javascript
JavaScript实现重力下落与弹性效果的方法分析
Dec 20 Javascript
es6新特性之 class 基本用法解析
May 05 Javascript
jQuery bind事件使用详解
May 05 #Javascript
javascript 拖动表格行实现代码
May 05 #Javascript
小试JQuery的AutoComplete插件
May 04 #Javascript
为你的网站增加亮点的9款jQuery插件推荐
May 03 #Javascript
通过jquery的$.getJSON做一个跨域ajax请求试验
May 03 #Javascript
Jquery 绑定时间实现代码
May 03 #Javascript
jqgrid 简单学习笔记
May 03 #Javascript
You might like
开发大型 PHP 项目的方法
2007/01/02 PHP
php获取本地图片文件并生成xml文件输出具体思路
2013/04/27 PHP
基于php在各种web服务器的运行模式详解
2013/06/03 PHP
PHP用continue跳过本次循环中剩余代码的注意点
2017/06/27 PHP
js解析xml字符串和xml文档实现原理及代码(针对ie与火狐)
2013/02/02 Javascript
JS+CSS 制作的超级简单的下拉菜单附图
2013/11/22 Javascript
jquery live()重复绑定的解决方法介绍
2014/01/03 Javascript
javascript中attribute和property的区别详解
2014/06/05 Javascript
javascript中clone对象详解
2014/12/03 Javascript
JS实现点击文字对应DIV层不停闪动效果的方法
2015/03/02 Javascript
在 Express 中使用模板引擎
2015/12/10 Javascript
基于bootstrap插件实现autocomplete自动完成表单
2016/05/07 Javascript
详解为Angular.js内置$http服务添加拦截器的方法
2016/12/20 Javascript
jQuery模拟下拉框选择对应菜单的内容
2017/03/07 Javascript
Angular.js中处理页面闪烁的方法详解
2017/03/09 Javascript
vue2中filter()的实现代码
2017/07/09 Javascript
vue开发调试神器vue-devtools使用详解
2017/07/13 Javascript
vue返回上一页面时回到原先滚动的位置的方法
2018/12/20 Javascript
解决layui动态添加的元素click等事件触发不了的问题
2019/09/20 Javascript
Vue3 的响应式和以前有什么区别,Proxy 无敌?
2020/05/20 Javascript
[01:17:12]职来职往完美电竞专场
2014/09/18 DOTA
Python 过滤字符串的技巧,map与itertools.imap
2008/09/06 Python
Python实现统计文本文件字数的方法
2017/05/05 Python
Python编程之string相关操作实例详解
2017/07/22 Python
pyqt5 键盘监听按下enter 就登陆的实例
2019/06/25 Python
Python判断三段线能否构成三角形的代码
2020/04/12 Python
Python和Bash结合在一起的方法
2020/11/13 Python
html5通过postMessage进行跨域通信的方法
2017/12/04 HTML / CSS
canvas压缩图片以及卡片制作的方法示例
2018/12/04 HTML / CSS
加拿大时尚潮流大码女装购物网站:Addition Elle
2018/04/02 全球购物
内勤主管岗位职责
2014/04/03 职场文书
解除聘用合同证明书范本
2014/09/11 职场文书
大学生预备党员自我评价
2015/03/04 职场文书
2015年机关后勤工作总结
2015/05/26 职场文书
初婚未育证明样本
2015/06/18 职场文书
公司职员入党自传书
2015/06/26 职场文书