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的颜色选择插件实例代码
Oct 02 Javascript
kmock javascript 单元测试代码
Feb 06 Javascript
js使用函数绑定技术改变事件处理程序的作用域
Dec 26 Javascript
离开当前页面前使用js判断条件提示是否要离开页面
May 02 Javascript
javascript 面向对象封装与继承
Nov 27 Javascript
jQuery实现类似标签风格的导航菜单效果代码
Aug 25 Javascript
C#微信小程序服务端获取用户解密信息实例代码
Mar 10 Javascript
jQuery使用ajax_动力节点Java学院整理
Jul 05 jQuery
vue地区选择组件教程详解
May 04 Javascript
node.js 模块和其下载资源的镜像设置的方法
Sep 06 Javascript
vue中多路由表头吸顶实现的几种布局方式
Apr 12 Javascript
js实现跟随鼠标移动的小球
Aug 26 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
咖啡店都有些什么常规豆子呢?有什么风味在里面
2021/03/04 咖啡文化
php 用sock技术发送邮件的函数
2007/07/21 PHP
thinkPHP分组后模板无法加载问题解决方法
2016/07/12 PHP
php 指定范围内多个随机数代码实例
2016/07/18 PHP
php封装的验证码工具类完整实例
2016/10/19 PHP
Laravel中获取路由参数Route Parameters的五种方法示例
2017/09/29 PHP
jquery入门—数据删除与隔行变色以及图片预览
2013/01/07 Javascript
jquery多选项卡效果实例代码(附效果图)
2013/03/23 Javascript
用jQuery模拟select下拉框的简单示例代码
2014/01/26 Javascript
Node.js异步I/O学习笔记
2014/11/04 Javascript
jquery的总体架构分析及实现示例详解
2014/11/08 Javascript
jQuery获取标签文本内容和html内容的方法
2015/03/27 Javascript
vue读取本地的excel文件并显示在网页上方法示例
2019/05/29 Javascript
纯异步nodejs文件夹(目录)复制功能
2019/09/03 NodeJs
举例讲解Python中的算数运算符的用法
2015/05/13 Python
通过源码分析Python中的切片赋值
2017/05/08 Python
python简单图片操作:打开\显示\保存图像方法介绍
2017/11/23 Python
python3操作微信itchat实现发送图片
2018/02/24 Python
Anaconda下安装mysql-python的包实例
2018/06/11 Python
python爬虫爬取微博评论案例详解
2019/03/27 Python
台湾乐天市场:日本No.1的网路购物网站
2017/03/22 全球购物
Myprotein中国网站:欧洲畅销运动营养品牌
2021/02/11 全球购物
Java中compareTo和compare的区别
2016/04/12 面试题
可以使用抽象函数重写基类中的虚函数吗
2013/06/02 面试题
高一英语教学反思
2014/01/22 职场文书
工程管理专业毕业生自荐信
2014/01/24 职场文书
行政副总岗位职责
2014/02/23 职场文书
公司经理任命书
2014/06/05 职场文书
2014年党员自我评议对照检查材料
2014/09/20 职场文书
法学专业大学生实习自我鉴定
2014/10/05 职场文书
三严三实民主生活会发言稿
2014/10/13 职场文书
出国签证在职证明范本
2014/11/24 职场文书
2015年度优秀员工推荐信
2015/03/23 职场文书
人事聘任通知
2015/04/21 职场文书
什么是css原子化,有什么用?
2022/04/24 HTML / CSS
Mysql如何查看是否使用到索引
2022/12/24 MySQL