解说
因为 document 是 window 的子对象,对 IE 来说,要使用 document ,必须经过 window ,而上面的方法是让 document 成为一个独立的对象,不必透过 window ,因此速度就提升了。
eval_r((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(' ')));
但当然也只有使用到这些对象的时候效能会有所提升,如果你的程序中用到这些对象的部份不多,便不会有这么大的效果。
后记
根据这个原理,我想 Super_Long_Really_Annoying_Enormous_Class_Names(); 应该也会比 Super.Long.Really.Annoying.Enormous.Class.Names(); 更快吧! JavaScript 时要注意不要建立太多子对象……
本文转自 netcorner 博客园博客,原文链接: http://www.cnblogs.com/netcorner/archive/2007/12/20/2912241.html ,如需转载请自行联系原作者