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 相关文章推荐
fromCharCode和charCodeAt 方法
Dec 27 Javascript
javaScript call 函数的用法说明
Apr 09 Javascript
理解Javascript_14_函数形式参数与arguments
Oct 20 Javascript
jQuery extend 的简单实例
Sep 18 Javascript
你不知道的高性能JAVASCRIPT
Jan 18 Javascript
浅谈Vue的基本应用
Dec 27 Javascript
Bootstrap table 定制提示语的加载过程
Feb 20 Javascript
js中获取键盘按下键值event.keyCode、event.charCode和event.which的兼容性详解
Mar 15 Javascript
Bootstrap实现的表格合并单元格示例
Feb 06 Javascript
微信小程序实现单列下拉菜单效果
Apr 25 Javascript
解决Layui 表格自适应高度的问题
Nov 15 Javascript
小程序跳转H5页面的方法步骤
Mar 06 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+MYSQL 出现乱码的解决方法
2008/08/08 PHP
php数组函数序列之sort() 对数组的元素值进行升序排序
2011/11/02 PHP
php冒泡排序、快速排序、快速查找、二维数组去重实例分享
2014/04/24 PHP
PHP开发框架Laravel数据库操作方法总结
2014/09/03 PHP
thinkPHP模板算术运算相关函数用法分析
2016/07/12 PHP
Thinkphp结合ajaxFileUpload实现异步图片传输示例
2017/03/13 PHP
JavaScript开发时的五个注意事项
2007/12/08 Javascript
jquery.ui.draggable中文文档
2009/11/24 Javascript
汉化英文版的Dreamweaver CS5并自动提示jquery
2010/11/25 Javascript
JavaScript高级程序设计 错误处理与调试学习笔记
2011/09/10 Javascript
仿谷歌主页js动画效果实现代码
2013/07/14 Javascript
JS自定义功能函数实现动态添加网址参数修改网址参数值
2013/08/02 Javascript
JavaScript使用slice函数获取数组部分元素的方法
2015/04/06 Javascript
javascript结合CSS实现苹果开关按钮特效
2015/04/07 Javascript
jQuery实现标题有打字效果的焦点图代码
2015/11/16 Javascript
JavaScript 经典实例日常收集整理(常用经典)
2016/03/30 Javascript
JS常用字符串方法(推荐)
2021/01/15 Javascript
javaScript中封装的各种写法示例(推荐)
2017/07/03 Javascript
vue 添加vux的代码讲解
2017/11/30 Javascript
如何在vue里面优雅的解决跨域(路由冲突问题)
2019/01/20 Javascript
11个Javascript小技巧帮你提升代码质量(小结)
2020/12/28 Javascript
Python中元组,列表,字典的区别
2017/05/21 Python
python使用Plotly绘图工具绘制柱状图
2019/04/01 Python
用Python画一个LinkinPark的logo代码实例
2019/09/10 Python
python解包用法详解
2021/02/17 Python
Autopep8的使用(python自动编排工具)
2021/03/02 Python
LookFantastic丹麦:英国美容护肤精品在线商城
2016/08/18 全球购物
香港个人化生活购物网站:Ballyhoo Limited
2016/09/10 全球购物
幼儿园元旦亲子活动方案
2014/02/17 职场文书
幼儿园元旦家长感言
2014/02/27 职场文书
民事诉讼代理委托书
2014/10/08 职场文书
业务员岗位职责
2015/02/03 职场文书
2015毕业生实习期工作总结
2015/04/09 职场文书
广播稿:校园广播稿范文
2019/04/17 职场文书
Matplotlib可视化之添加让统计图变得简单易懂的注释
2021/06/11 Python
彻底解决MySQL使用中文乱码的方法
2022/01/22 MySQL