一行代码加速IE的javascript的方法

将下列代码加在JavaScript的最前面

/*@cc_on_d=document;eval('var document=_d')@*/

加入这样的一行代码IEdocument的访问速度至少可以提高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

速度提高了不少吧!

解说:

首先,IEdocument就这样直接被调用的话被执行的是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('')));

@*/

转自:http://blog.minidx.com/2007/10/15/13.html

阅读更多
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭