用一行简单的代码就能加速IE运行脚本的速度
2016-06-07 22:28
441 查看
将下列代码加在JavaScript的最前面
/*@cc_on_d=document;eval('var document=_d')@*/
加入这样的一行代码IE的document的访问速度至少可以提高5倍以上
下面是加入前和加入后的测试比较代码
// Before
var date = new Date;
for (var i = 0; i < 100000; i++) document;
alert(new Date - date); // 643
/*@cc_on_d=document;eval('var document=_d')@*/
// After
date = new Date;
for (var i = 0; i < 100000; i++) document;
alert(new Date - date); // 145
速度提高了不少吧!
解说:
首先,IE里document就这样直接被调用的话被执行的是window 对象的内部函数,而这个比较低效的。根据这一点,下面的处理可以提高速度:
var doc = document;
document; // 慢
doc; // 这个比上面的(document)快
虽然像上面那么写可以直接使用,但是之前用到document的地方都要去替换,这个有点麻烦了点吧。所以,看下面的:
var doc = document;
var document = doc;
可以实现的话那就太好了……
了解JavaScript的人应该知道,JavaScript的变量是在最开始的时候就生成的,所以这里的document就变成了undefined了。
没关系,继续改进~
var doc = document;
eval('var document = doc');
eval的作用就是在作用域范围内改变变量,这样的话,后面的document就可以被正常使用了。
最后,加上只有在IE内有效的条件,就像下面这样就可以了~
/*@cc_on
var doc = document;
eval('var document = doc');
@*/
举一反三,像下面这样的写法,document以外的全局变量也可以用上面的方法,起到加速的作用。
/*@cc_on
eval((function(props) {
var code = [];
for (var i = 0 l =props.length;i<l;i++){
var prop = props[i];
window['_'+prop]=window[prop];
code.push(prop+'=_'+prop)
}
return 'var '+code.join(',');
})('document self top parentalert setInterval clearInterval
setTimeout clearTimeout'.split('')));
@*/
/*@cc_on_d=document;eval('var document=_d')@*/
加入这样的一行代码IE的document的访问速度至少可以提高5倍以上
下面是加入前和加入后的测试比较代码
// Before
var date = new Date;
for (var i = 0; i < 100000; i++) document;
alert(new Date - date); // 643
/*@cc_on_d=document;eval('var document=_d')@*/
// After
date = new Date;
for (var i = 0; i < 100000; i++) document;
alert(new Date - date); // 145
速度提高了不少吧!
解说:
首先,IE里document就这样直接被调用的话被执行的是window 对象的内部函数,而这个比较低效的。根据这一点,下面的处理可以提高速度:
var doc = document;
document; // 慢
doc; // 这个比上面的(document)快
虽然像上面那么写可以直接使用,但是之前用到document的地方都要去替换,这个有点麻烦了点吧。所以,看下面的:
var doc = document;
var document = doc;
可以实现的话那就太好了……
了解JavaScript的人应该知道,JavaScript的变量是在最开始的时候就生成的,所以这里的document就变成了undefined了。
没关系,继续改进~
var doc = document;
eval('var document = doc');
eval的作用就是在作用域范围内改变变量,这样的话,后面的document就可以被正常使用了。
最后,加上只有在IE内有效的条件,就像下面这样就可以了~
/*@cc_on
var doc = document;
eval('var document = doc');
@*/
举一反三,像下面这样的写法,document以外的全局变量也可以用上面的方法,起到加速的作用。
/*@cc_on
eval((function(props) {
var code = [];
for (var i = 0 l =props.length;i<l;i++){
var prop = props[i];
window['_'+prop]=window[prop];
code.push(prop+'=_'+prop)
}
return 'var '+code.join(',');
})('document self top parentalert setInterval clearInterval
setTimeout clearTimeout'.split('')));
@*/
相关文章推荐
- 第15周阅读程序(1)
- 使用spring mvc前台获取后台返回的List
- java应用cpu过高
- javaweb学习总结(四十四)——监听器(Listener)学习
- java 8之Lambda Expressions 解说
- java 数组实现哈希表的构建,查找,插入,删除
- 中文javadoc
- 中文javadoc
- spring的事物配置
- javaweb学习总结(四十六)——Filter(过滤器)常见应用
- Eclipse提升开发效率的快捷键
- java生成word的完美解决方案
- Google gflags基础与进阶
- java异常错误
- lua入门
- AlphaGo算法框架解读
- python-day0003-搭建基于python的selenium自动化测试---元素定位
- Windows服务代码控制安装卸载、启动停止
- 输出日历
- Leetcode_c++: Largest Rectangle in Histogram (084)