手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >加速IE的Javascript document输出的方法
加速IE的Javascript document输出的方法
摘要:将下列代码加在JavaScript的最前面复制代码代码如下:/*@cc_on_d=document;eval('vardocument=_d...

将下列代码加在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 parent alert setInterval clearInterval

setTimeout clearTimeout'.split(' ‘)));

@*/

下面是Franky的回复:

首先,IE里document就这样直接被调用的话被执行的是window 对象的内部函数,而这个比较低效的。根据这一点,下面的处理可以提高速度:

这个说法 不对..

之所以 你的测试 前后有差异,主要区别在于作用域链查找.

你的代码 是在global 执行环境.所以IE下,会访在global对象去查找 key 为'document'的成员. 而这个对象在ie中是一个com+实现的宿主对象. 他不在global中. global中没有,则去window中再次查找.造成了速度变慢.

同样的全局对象 Math. 就不会带来这个问题.原因是Math 在 Global上. 一次作用域链查找就找到了.

对于优化. 一个建议就是

var win = window, doc = document,undefined;

每层作用域内,如果这个成员使用超过两次,就有意义.

而如果你只在全局作用域 使用一次 ie 条件注释 ,首先 非ie就无法享受到作用域被缩短的好处. 当然非ie 不会存在global->window的 多一次责任链查找.

这里的优化核心,就是缩短作用域链. 虽然opera chrome safarai等较新版本,对作用域链查找做了优化. 但是我们认为的缩短作用域链. 对老的浏览器是有积极作用的.且对具备优化的浏览器,也不会带来过于负的面影响.

【加速IE的Javascript document输出的方法】相关文章:

JavaScript中使用Math.PI圆周率属性的方法

javascript模拟评分控件实现方法

JavaScript深度复制(deep clone)的实现方法

javascript动态创建链接的方法

javascript实现模拟时钟的方法

简介JavaScript中用于处理正切的Math.tan()方法

Javascript监视变量变化的方法

javascript中attachEvent用法

JavaScript中substring()方法的使用

JavaScript获取并更改input标签name属性的方法

精品推荐
分类导航