加速IE的Javascript的方法
將下列代碼加在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(’ ‘)));
@*/
轉載:http://purpen.javaeye.com/?page=8&show_full=true
轉載于:https://www.cnblogs.com/xiaopin/archive/2010/12/01/1892692.html
總結
以上是生活随笔為你收集整理的加速IE的Javascript的方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ospf与辅助接口实验
- 下一篇: 伦敦眼(说一说伦敦眼的简介)