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 相关文章推荐
jQuery 行级解析读取XML文件(附源码)
Oct 12 Javascript
JS 实现Json查询的方法实例
Apr 12 Javascript
用html+css+js实现的一个简单的图片切换特效
May 28 Javascript
node.js中的events.EventEmitter.listenerCount方法使用说明
Dec 08 Javascript
js实现根据身份证号自动生成出生日期
Dec 15 Javascript
用原生JS对AJAX做简单封装的实例代码
Jul 13 Javascript
jquery-mobile基础属性与用法详解
Nov 23 Javascript
JS实现根据指定值删除数组中的元素操作示例
Aug 02 Javascript
React优化子组件render的使用
May 12 Javascript
小程序多图列表实现性能优化的方法步骤
May 28 Javascript
layui点击左侧导航栏,实现不刷新整个页面,只刷新局部的方法
Sep 25 Javascript
Angular+ionic实现折叠展开效果的示例代码
Jul 29 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写的求多项式导数的函数代码
2012/07/04 PHP
PHP获取和操作配置文件php.ini的几个函数介绍
2013/06/24 PHP
Thinkphp使用mongodb数据库实现多条件查询方法
2014/06/26 PHP
PHPCMS V9 添加二级导航的思路详解
2016/10/20 PHP
PHP+Ajax实现上传文件进度条动态显示进度功能
2018/06/04 PHP
理解 JavaScript 预解析
2009/10/25 Javascript
JavaScript游戏之优化篇
2010/11/08 Javascript
jquery.bgiframe.js在IE9下提示INVALID_CHARACTER_ERR错误
2013/01/11 Javascript
js实现点击左右按钮轮播图片效果实例
2015/01/29 Javascript
jquery代码实现多选、不同分享功能
2015/07/31 Javascript
分类解析jQuery选择器
2016/11/23 Javascript
jQuery插件FusionCharts实现的3D柱状图效果实例【附demo源码下载】
2017/03/03 Javascript
Vue中mintui的field实现blur和focus事件的方法
2018/08/25 Javascript
js+html5 canvas实现ps钢笔抠图
2019/04/28 Javascript
微信小程序实现弹出菜单动画
2019/06/21 Javascript
js判断鼠标移入移出方向的方法
2020/06/24 Javascript
vue实现图片上传到后台
2020/06/29 Javascript
通过angular CDK实现页面元素拖放的步骤详解
2020/07/01 Javascript
js调用网络摄像头的方法
2020/12/05 Javascript
[03:53]2016国际邀请赛中国区预选赛第三日TOP10精彩集锦
2016/06/29 DOTA
在Python中关于中文编码问题的处理建议
2015/04/08 Python
python脚本替换指定行实现步骤
2017/07/11 Python
Python基于回溯法子集树模板实现8皇后问题
2017/09/01 Python
解决python3爬虫无法显示中文的问题
2018/04/12 Python
python实现微信自动回复及批量添加好友功能
2019/07/03 Python
Python爬虫之Selenium多窗口切换的实现
2020/12/04 Python
英国领先的狗和宠物美容专家:Christies Direct
2017/04/03 全球购物
比利时香水网上商店:NOTINO
2018/03/28 全球购物
日本最佳原创设计品牌:Felissimo(芬理希梦)
2019/03/19 全球购物
研修第一天随笔感言
2014/02/15 职场文书
中学生评语大全
2014/04/18 职场文书
公共场所标语
2014/06/30 职场文书
物理课外活动总结
2014/08/27 职场文书
导游词之重庆渣滓洞
2020/01/08 职场文书
Java中PriorityQueue实现最小堆和最大堆的用法
2021/06/27 Java/Android
【TED出品】天梯非主流开心游1700 划水骑士
2022/03/31 魔兽争霸