现在的位置: 首页 > 综合 > 正文

一行代码加速IE的JavaScript的方法!

2013年10月02日 ⁄ 综合 ⁄ 共 1252字 ⁄ 字号 评论关闭

导读:
  将下列代码加在JavaScript的最前面
  /*@cc_on _d=document;eval(’var document=_d’)@*/
  加入这样的一行代码IE的document的访问速度至少可以提高5倍以上
  下面是加入前和加入后的测试比较代码
  // Before
  var date = new Date;
  for (var i = 0; i   alert(new Date - date); // 643
  /*@cc_on _d=document;eval(’var document=_d’)@*/
  // After
  date = new Date;
  for (var i = 0; i   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  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://blog.minidx.com/2007/10/15/13.html

本文转自
http://purpen.javaeye.com/blog/151966

抱歉!评论已关闭.