`
purpen
  • 浏览: 796885 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

一行代码加速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://blog.minidx.com/2007/10/15/13.html
分享到:
评论

相关推荐

    加速IE的Javascript document输出的方法

    @*/ 加入这样的一行代码IE的document的访问速度至少可以提高5倍以上 下面是加入前和加入后的测试比较代码 代码如下: // Before var date = new Date; for (var i = 0; i &lt; 100000; i++) document; alert&#40;new ...

    IE10兼容性白皮书

    - 实现方法简单易行。 **3. Programmable HTTP Cache and Serving:** - **定义:**该功能允许 Web 应用内容动态写入浏览器缓存。 - **优势:** - 大幅提升应用的响应速度,接近本地应用的表现。 - 改善用户体验...

    如何用 JavaScript 开发一款超越式赛车游戏.zip

    如何用 JavaScript 开发一款超越式赛车游戏Javascript 伪 3D 赛车一款使用 HTML5 和 Javascript 编写的 Outrun 风格伪 3D 赛车游戏玩游戏查看源代码了解它的工作原理逐步构建为 4 个部分播放直路演示播放曲线演示...

    jCube只需添加一行js脚本就可以创建出一个可以拖动旋转的3d立方体

    然后,在JavaScript中,使用一行代码初始化并设置3D立方体: ```javascript new jCube(document.getElementById('cube-container')); ``` 这行代码会查找id为`cube-container`的元素,并在其内部创建一个可交互的...

    javascript面试题

    - **块级元素**:独占一行显示,可以设置宽度和高度。 - 行内元素可以设置左右 `margin` 和 `padding`,但上下 `margin` 和 `padding` 仅影响元素内部空间,不影响其他元素。 **25、什么是外边距重叠?重叠的结果是...

    jQuery实用导航上下滑动及左右切换效果demo

    左右切换效果常见于水平导航菜单,尤其是当菜单项过多,无法在一行内完全显示时。我们可以使用`slideToggle()`函数来实现这种效果。同样,我们需要监听菜单项的`click`事件,并根据用户的点击执行滑动切换。 3. **...

    web前端面试题及答案【前端开发面试题及答案整理】.docx

    行内元素(如`&lt;span&gt;`、`&lt;a&gt;`)在一行内显示,不占据整块空间;块级元素(如`&lt;div&gt;`、`&lt;p&gt;`)会独占一行。CSS盒模型包括内容(Content)、边距(Margin)、填充(Padding)和边框(Border),定义了元素的总尺寸。 ...

    ExtAspNet v2.2.1 (2009-4-1) 值得一看

    -Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第一个按钮设置CssStyle="float:left;"属性。 -修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。 -为TriggerBox...

    ExtAspNet_v2.3.2_dll

    -Button控件将不再自动拥有display:inline属性,如果希望两个按钮在一行显示,请为第一个按钮设置CssStyle="float:left;"属性。 -修正了弹出菜单的位置在Firefox下不正确的BUG(feedback:eroach)。 -为TriggerBox...

    《前端手册》

    - 规则中包含多个选择器时,每个选择器声明独占一行。 - `&gt;`、`+`、`~`选择器两边各保留一个空格。 - 属性选择器中的值必须用双引号包围。 3. **属性**: - 属性定义必须另起一行。 - 属性定义后必须以分号...

    70款经典Dreamweaver插件

    ie_favicon 你只需要一个漂亮的ico格式图片,您的地址栏IE图标将与众不同 favorite_menu 为DW增加一个Favorites 菜单,类似IE收藏夹 layer_transitions 层的多种转换特效 dhtml_tooltips 为页面或链接增加一个dHTML...

    前端开发面试题

    - **IE5+**:使用 `attachEvent` 方法。 - **DOM0**:直接赋值给元素的事件处理程序属性。 #### `window.onbeforeunload` 的用法 - 该事件发生在窗口即将关闭之前。 - 可用于提示用户保存数据等操作。 - 具体使用...

    Dreamweaver 插件集

    你只需要一个漂亮的ico格式图片,您的地址栏IE图标将与众不同 favorite_menu 为DW增加一个Favorites 菜单,类似IE收藏夹 layer_transitions 层的多种转换特效 dhtml_tooltips 为页面或链接增加一个dHTML的脚注(即...

    INSPINIA - Responsive Admin Theme 2.9.4

    2. **jQuery库**:作为Bootstrap的一部分,jQuery是一个广泛使用的JavaScript库,简化了DOM操作、事件处理、动画和Ajax交互,使开发者能更高效地编写代码。 3. **UI组件**:INSPINIA包含了大量的UI组件,如导航栏、...

    精通AngularJS part1

    promise是第一类JavaScript对象87 聚合回调88 注册回调和承诺的生命周期88 异步动作的链式调用89 关于$q的其他91 AngularJS中的$q集成93 33promiseAPI与$http94 34与RESTful端点通信95 $resource服务95 ...

    web前端面试题

    - 行内元素与其他元素在同一行显示,而块级元素则独占一行。 - 行内元素可以设置 padding 和 margin,但 margin 的 top 和 bottom 仅影响其周围的元素。 **23. 什么是外边距重叠?重叠的结果是什么?** - 外边距...

    面试宝典之吊打面试官系列

    - **行内元素**: 默认在同一行显示,宽度自动调整。 - **块级元素**: 默认独占一行,宽度默认为100%。 - 行内元素的`padding`和`margin`的上下值无效。 **23. 外边距重叠** - **问题**: 什么是外边距重叠?重叠...

    尚硅谷_前端_面试题

    - 使用CDN加速CSS文件的加载。 - 使用媒体查询优化移动设备的样式。 29. **浏览器是怎样解析CSS选择器的?** - 浏览器首先解析HTML文档,然后根据CSS规则找到匹配的选择符,并应用相应的样式。解析过程中,...

    web前端面试宝典

    - **块级元素**:独占一行,可以设置宽度和高度。 - **可设置margin和padding**:行内元素的margin只能设置左右,而padding可以设置上下。 **转换方法**: - `display: inline`或`inline-block`。 - `display: ...

Global site tag (gtag.js) - Google Analytics