JS 网站性能优化笔记


Posted in PHP onMay 24, 2011

1. 除去JavaScript注释

除了注释,其他所有的 // or /* */ 注释都可以安全删除,因为它们对于最终使用者来说没有任何意义。

2. 除去JavaScript中的空白区域

如:x = x + 1;  可以简短得写成:x=x+1;  。

3. 进行代码优化

简单的方法如除去暗示的(implied)分号,某些情形下的变量声明或者空回车语句都可以进一步减少脚本代码。一些简略的表达方式也会产生很好的优化,例如:

x=x+1;

可以写成:

x++;

不过得小心谨慎,不然代码很容易出错。

4. 重命名用户自定义的变量和函数

为了阅读方便,我们都知道在脚本中应该使用象sumTotal这样的变量而不是s。不过,考虑到下载的速度,sumTotal这个变量就显得冗长了。这个长度对于最终使用者来说没有意义,但对浏览器下载则是个负担。这个时候s就成为较好的选择了。先写好方便阅读的代码,然后再使用一些工具来处理以供交付。这种处理方式在这里再一次展示了其价值所在。将所有的名称都重新用一个或两个字母来命名将带来显著的改善。

5. 改写内建(built-in)对象

长长用户变量名会造成JavaScript代码过长,除此之外,内建(built-in)对象(比如Window、Document、Navigator等)也是原因之一。例如:

alert(window.navigator.appName);
alert(window.navigator.appVersion);
alert(window.navigator.userAgent);

可以改写成如下简短的代码:

w=window;n=w.navigator;a=alert;
a(n.appName);
a(n.appVersion);
a(n.userAgent);

如果这几个对象使用频繁的话,这样改写带来的好处就不言而喻了。事实上这些对象也的确经常被调用。然而我要提醒的是,如果Window或 Navigator对象仅仅被使用了一次的话,这样的替换反而使代码变得更长。这个技巧带来一个对象更名后脚本执行效率的问题:除了代码长短上带来的好处,这种改写更名实际上还会稍微的提高一点脚本执行的速度,因为这些对象将会被放在所有被调用对象中比较靠前的位置。JavaScript游戏开发程序员使用这个技巧已经有多年了,下载和执行速度都会有所提高,并且对本地浏览器的内存花销也会降低,可谓一石三鸟。

6. 重构<script>和<style> 调用方式来优化请求次数

我们常常在一个HTML文件头中看到这样标记代码:

<script src="/scripts/rollovers.js"></script>
<script src="/scripts/validation.js"></script>
<script src="/scripts/tracking.js"></script>

大多数情况下,上述代码应该被简化成:

<script src="/0/g.js"></script>

其中g.js包含了所有供全局使用的函数。虽然把脚本文件分成三份对于维护来说是有道理的,但对于代码的传输则没有意义。单个的脚本下载要比三个分离的请求高效的多,并且这也同时简化了markup代码的长度。

7. 合并你的javascript文件

尽可能的减少HTTP的Request请求数。

8. 将脚本放到网页底部

    脚本一般是用来于用户交互的。所以如果页面还没有出来,用户连页面都不知道什么样子,那谈交互简直就是扯谈。所以,脚本和CSS正好相反,脚本应该放在页面的底部。

    PHP 相关文章推荐
    非常好用的两个PHP函数 serialize()和unserialize()
    Feb 04 PHP
    PHP中使用crypt()实现用户身份验证的代码
    Sep 05 PHP
    PHP在不同页面间传递Json数据示例代码
    Jun 08 PHP
    php防注入,表单提交值转义的实现详解
    Jun 10 PHP
    PHP实现根据浏览器跳转不同语言页面代码
    Aug 02 PHP
    PHP的魔术常量__METHOD__简介
    Jul 08 PHP
    php防止伪造数据从地址栏URL提交的方法
    Aug 24 PHP
    基于PHP实现商品成交时发送短信功能
    May 11 PHP
    thinkphp配置文件路径的实现方法
    Aug 30 PHP
    PHP商品秒杀问题解决方案实例详解【mysql与redis】
    Jul 22 PHP
    PHP读取Excel内的图片(phpspreadsheet和PHPExcel扩展库)
    Nov 19 PHP
    PHP filter_var() 函数, 验证判断EMAIL,URL等
    Mar 09 PHP
    PHP文件打开、关闭、写入的判断与执行代码
    May 24 #PHP
    php Rename 更改文件、文件夹名称
    May 24 #PHP
    php fputcsv命令 写csv文件遇到的小问题(多维数组连接符)
    May 24 #PHP
    php 定界符格式引起的错误
    May 24 #PHP
    php file_put_contents()功能函数(集成了fopen、fwrite、fclose)
    May 24 #PHP
    mac下使用brew配置环境的步骤分享
    May 23 #PHP
    PHP取得一个类的属性和方法的实现代码
    May 22 #PHP
    You might like
    jQuery MD5加密实现代码
    2010/03/15 Javascript
    有趣的javascript数组定义方法
    2010/09/10 Javascript
    JavaScript中两种链式调用实现代码
    2011/01/12 Javascript
    JQuery扩展插件Validate 2通过参数设置验证规则
    2011/09/05 Javascript
    javascript 表格内容排序 简单操作示例代码
    2014/01/03 Javascript
    js判断设备是否为PC并调整图片大小
    2014/02/12 Javascript
    JS实现同时搜索百度和必应的方法
    2015/01/27 Javascript
    JavaScript 事件绑定及深入
    2015/04/13 Javascript
    JavaScript正则表达式匹配 div  style标签
    2016/03/15 Javascript
    AngularJS 遇到的小坑与技巧小结
    2016/06/07 Javascript
    JS实现瀑布流布局
    2017/10/21 Javascript
    JavaScript设计模式之模板方法模式原理与用法示例
    2018/08/07 Javascript
    vue.js 中使用(...)运算符报错的解决方法
    2018/08/09 Javascript
    使用 Node.js 实现图片的动态裁切及算法实例代码详解
    2018/09/29 Javascript
    微信小程序开发之点击按钮退出小程序的实现方法
    2019/04/26 Javascript
    VUE table表格动态添加一列数据,新增的这些数据不可以编辑(v-model绑定的数据不能实时更新)
    2020/04/03 Javascript
    微信小程序实现自定义底部导航
    2020/11/18 Javascript
    jQuery实现购物车全功能
    2021/01/11 jQuery
    使用python提取html文件中的特定数据的实现代码
    2013/03/24 Python
    python下载文件时显示下载进度的方法
    2015/04/02 Python
    用Python将IP地址在整型和字符串之间轻松转换
    2017/03/22 Python
    Python 列表(List) 的三种遍历方法实例 详解
    2017/04/15 Python
    python 显示数组全部元素的方法
    2018/04/19 Python
    pandas pivot_table() 按日期分多列数据的方法
    2018/11/16 Python
    OpenCV+python实现实时目标检测功能
    2020/06/24 Python
    纯CSS3实现鼠标滑过按钮动画第二节
    2020/07/16 HTML / CSS
    请编程遍历页面上所有 TextBox 控件并给它赋值为 string.Empty
    2015/12/03 面试题
    甜品蛋糕店创业计划书范文
    2014/02/06 职场文书
    工程专业求职自荐书范文
    2014/02/08 职场文书
    船舶工程技术专业求职信
    2014/08/07 职场文书
    珍惜资源的建议书
    2014/08/26 职场文书
    搞笑老公保证书
    2015/02/26 职场文书
    指导老师鉴定意见
    2015/06/05 职场文书
    致接力运动员加油稿
    2015/07/21 职场文书
    礼仪培训心得体会
    2016/01/22 职场文书
    python之基数排序的实现
    2021/07/26 Python