`
反求诸己
  • 浏览: 543381 次
  • 性别: Icon_minigender_1
  • 来自: 湖南娄底
社区版块
存档分类
最新评论

iframe异步加载技术及性能<转>

阅读更多

这是一篇原创翻译文章<原翻译网址:http://www.cnblogs.com/beiyuu/archive/2011/07/18/iframe-tech-performance.html>。原文地址

我们会经常使用iframes来加载第三方的内容、广告或者插件。使用iframe是因为他可以和主页面并行加载,不会阻塞主页面。当然使用iframe也是有利有弊的:Steve Souders在他的blog里面有阐述:Using Iframes Sparingly :

  • iframe会阻塞主页面的onload事件
  • 主页面和iframe共享同一个连接池

阻塞主页面的onload是这两个问题中最影响性能的方面。一般都是想让onload时间越早触发越好,一方面是用户体验过更重要的是google给网站的加载速度的打分:用户可以用IE和FF中Google工具栏来计时。

那么为了提高页面性能,怎样才能不阻塞主页面的onload事件的来加载iframe呢?

这篇讲了四种加载iframe的方法:普通iframe,onload之后加载iframe,setTimeout() iframe和异步加载iframe。每种方法的加载结果我都用IE8的时间线来展示。我建议多注意下动态异步加载这个方法,因为这是性能表现最佳的。另 外,还有一种友好iframe(friendly iframe)技术。他可能算不上是iframe加载的技术,但是必须使用iframe,他是无阻塞加载的。

普通方法加载iframe

这是一种人尽皆知的普通加载方法,它没有浏览器的兼容性问题。

1

 <

iframe 

src

="/path/to/file"

 frameborder

="0"

 width

="728"

 height

="90"

 scrolling

="auto"

>

 

</

iframe

>

使用这种加载方法会在各浏览器中有如下表现:

  • iframe会在主页面的onload之前加载
  • iframe会在所有iframe的内容都加载完毕之后触发iframe的onload
  • 主页面的onload会在iframes的onload触发之后触发,所以iframe会阻塞主页面的加载
  • 当iframe在加载的过程中,浏览器的会标识正在加载东西,处于忙碌状态。

这里 是一个演示页面,时间线图显示出iframe会阻塞主页面的加载。

我的建议:注意onload阻塞。如果iframe的内容只需要很短的时间来加载和执行,那么也不是个大问题,而且使用这种方法还有个好处是可 以和主页面并行加载。但是如果加载这个iframe需要很长时间,用户体验就很差了。你得自己测试一下然后在 http://www.webpagetest.org/也做些测试,根据onload的时间看看是否需要其他加载方法。

在onload之后加载iframe

如果你想在iframe中加载一些内容,但是这些内容对于页面来说不是那么的重要。或者这些内容不需要马上展现给用户的,需要点击触发之类的。那么可以考虑在主页面载入之后加载iframe。
 1

 <

script

>




 2

 


 3

 //

doesn't block the load event




 4

 function

 createIframe() {


 5

     

var

 i 

=

 document.createElement(

"

iframe

"

);


 6

     i.src 

=

 

"

path/to/file

"

;


 7

     i.scrolling 

=

 

"

auto

"

;


 8

     i.frameborder 

=

 

"

0

"

;


 9

     i.width 

=

 

"

200px

"

;


10

     i.height 

=

 

"

100px

"

;


11

     document.getElementById(

"

div-that-holds-the-iframe

"

).appendChild(i);


12

 };


13

 //

 Check for browser support of event handling capability




14

 if

 (window.addEventListener) window.addEventListener(

"

load

"

, createIframe, 

false

);


15

 else

 

if

 (window.attachEvent) window.attachEvent(

"

onload

"

, createIframe);


16

 else

 window.onload 

=

 createIframe;


17

 <

/

script>

这种加载方法也是没有浏览器的兼容性问题的:

  • iframe会在主页面onload之后开始加载
  • 主页面的onload事件触发与iframe无关,所以iframe不会阻塞加载
  • 当iframe加载的时候,浏览器会标识正在加载

这是 是一个测试页面,时间线图如下

这种方法比普通方法有什么好处呢?load事件会马上触发,有两个好处:
  • 其他等待主页面onload事件的代码可以尽早执行
  • Google Toolbar计算你页面加载的时间会大大减少
但是,当iframe加载的时候,还是会看到浏览器的忙碌状态,相对于普通加载方法,用户看到忙碌状态的时间更长。还有就是用户还没等到页面完全加载完的时候就已经离开了。有些情况下这是个问题,比如广告。

setTimeout()来加载iframe

这种方法的目的是不阻塞onload事件。
Steve Souders(又是他?)有一个这种方法的测试页面(http://stevesouders.com/efws/iframe-onload- nonblocking.php)。他写道:“src通过setTimeout动态的设置,这种方法可以再所有的浏览器中避免阻塞”。
<

iframe id

=

"

iframe1

"

 src

=

""

 width

=

"

200

"

 height

=

"

100

"

 border

=

"

2

"

>


 

<

/

iframe>




<

script

>





function

 setIframeSrc() {
    

var

 s 

=

 

"

path/to/file

"

;
    

var

 iframe1 

=

 document.getElementById(

'

iframe1

'

);
    

if

 ( 

-

 

1

 

==

 navigator.userAgent.indexOf(

"

MSIE

"

)) {
        iframe1.src 

=

 s;
    } 

else

 {
        iframe1.location 

=

 s;
    }
}
setTimeout(setIframeSrc, 

5

);


<

/

script>

在除了IE8以外的所有浏览器中会有如下表现:
  • iframe会在主页面onload之前开始加载
  • iframe的onload事件会在iframe的内容都加载完毕之后触发
  • iframe不会阻塞主页面的onload事件(IE8除外)
  • 为什么不会阻塞主页面的onload呢(IE8除外)?因为setTimeout()
  • 当iframe加载的时候,浏览器会显示忙碌状态
下面是时间线图
因为IE8的问题,这种技术就不适合很多网站了。如果有超过10%的用户使用IE8,十分之一的用户体验就会差。你会说那也只是比普通加载差一 点点,其实普通加载性能上也不差。onload事件对于10%的用户来说都更长。。。。额,你自己考虑吧。但是最好在看了下面这个很赞的异步加载方法之后 再决定吧。
我在参加Velocity 2010的时候,Meebo的两个工程师(@marcuswestin and Martin Hunt)做了一个关于他们的Meebo Bar的演讲。他们使用iframe来加载一些插件,并且真正做到了无阻塞加载。对于有的开发者来说,他们的做法还比较新鲜。很赞,超级赞。但是一些原因 导致这种技术没有得到相应的关注,我希望这篇blog能把它发扬光大。
<

script

>



(

function

(d) {
    

var

 iframe 

=

 d.body.appendChild(d.createElement(

'

iframe

'

)),
    doc 

=

 iframe.contentWindow.document;
 
    

//

 style the iframe with some CSS




    iframe.style.cssText 

=

 

"

position:absolute;width:200px;height:100px;left:0px;

"

;
 
    doc.open().write(

'

<body onload="

'

 

+

 

'

var d = document;d.getElementsByTagName(\'head\')[0].

'

 

+

 

'

appendChild(d.createElement(\'script\')).src

'

 

+

 

'

=\'\/path\/to\/file\'">

'

);
 
    doc.close(); 

//

iframe onload event happens




})(document);


<

/

script>

神奇的地方就在<body onload=”">:这个iframe一开始没有内容,所以onload会立即触发。然后你创建一个script元素,用他来加载内容、广告、插 件什么的,然后再把这个script添加到HEAD中去,这样iframe内容的加载就不会阻塞主页面的onload!你应该看看他在个浏览器中的表现:
  • iframe会在主页面onload之前开始加载
  • iframe的onload会立即触发,因为iframe的内容一开始为空
  • 主页面的onload不会被阻塞
  • 为什么这个iframe不会阻塞主页面的onload?因为<body onload=”">
  • 如果你不在iframe使用onload监听,那么iframe的加载就会阻塞主页面的onload
  • 当iframe加载的时候,浏览器终于不显示忙碌状态了(非常好)
我的测试页 给出下面的时间线:
转义字符让代码看着有些难受,这都不是问题。试试吧。

友好型iframe加载

这是用来加载广告的。虽然这不是一种iframe的加载技术,但是是用iframe来盛放广告的。他的亮点不在于iframe如何加载,而是主页面、iframe、广告如何协同工作的。如下:
  • 先创建一个iframe。设置他的src为一个相同域名下的静态html文件
  • 在这个iframe里面,设置js变量inDapIF=true来告诉广告它已经加载在这个iframe里面了
  • 在这个iframe里面,创建一个script元素加上广告的url作为src,然后像普通广告代码一样加载
  • 当广告加载完成,重置iframe大小来适应广告
  • 这种方法也没有浏览器的兼容性问题。
Ad Ops Council在推荐过这个方法 ,AOL也是用这种方法。想看看源码:这里有一个 。一家瑞典的出版社Aftonbladet对于这种加载有很不错的结论:在他们的主页上,加载时间减少30%,用户每周增加7%,新闻部分的点击量增加35%。我建议可以看看他们的资料:High Performance Web Sites, With Ads: Don’t let third parties make you slow
我没有创建相关的测试页,所以也没有第一首的资料。从我调研的结果来说:
如果你只想在你的网页上调用一个确定的src地址的iframe的话这个方法不是很有用。
如果你想在网页上展示多个广告,比较灵活的方法的是:加载一个广告,然后更新iframe加载另一个主页面的DOMContentLoaded时间不会被阻塞,页面渲染也不会被阻塞,当然,主页面的onload事件还是会被阻塞。
分享到:
评论

相关推荐

    html 网页加载

    - 可以通过异步加载等方式优化加载性能。 4. **安全问题**: - 需要确保嵌入的内容来自可信任的源,避免潜在的安全风险。 - 使用`sandbox`属性可以增强安全性,限制`&lt;iframe&gt;`的内容执行脚本、提交表单等操作的...

    iframe 异步加载技术及性能分析

    【iframe异步加载技术】 在Web开发中,`iframe`(Inline Frame)常用于加载第三方内容,如广告、插件等。它的主要优点是能够与主页面并行加载,不阻塞主页面的渲染。然而,`iframe`的使用并非没有代价。正如Steve ...

    C#编程经验技巧宝典

    111&lt;br&gt;&lt;br&gt;0184 如何在ASP.NET中获取文件的扩展名 111&lt;br&gt;&lt;br&gt;0185 如何在ASP.NET中用URL在页面之间传值 112&lt;br&gt;&lt;br&gt;0186 如何使用IsPostBack实现ASP.NET页面加载 112&lt;br&gt;&lt;br&gt;0187 如何利用输出缓存技术缓存...

    异步加载script的代码

    在这种情况下,我们可以利用`&lt;iframe&gt;`标签来实现异步加载script。在给出的代码示例中,`a1.html`包含一个按钮,当用户点击按钮时,触发`testClick()`函数。这个函数将`&lt;iframe&gt;`的`src`属性设置为`a2.html`。`a2....

    最强面试八股文-前端篇

    `defer`会延迟脚本的执行,直到文档解析完成,而`async`则是在脚本下载完成时立即执行,两者都支持异步加载,但执行顺序不同,`async`执行顺序不可控,而`defer`则保证按照脚本在文档中的顺序执行。 DOCTYPE在HTML...

    您应该了解的独特 HTML 属性

    8. 异步:async 属性与 &lt;script&gt; 元素一起使用,指示脚本应该异步执行。例如:&lt;script async src="myscript.js"&gt;&lt;/script&gt; 该属性可以应用于脚本加载优化、页面性能优化等场景,提高页面加载速度。 9. 接受属性:...

    前端发展简介

    1996年的iframe标签允许异步加载局部内容,1999年XMLHttpRequest的引入则预示着Ajax技术的崛起,它实现了页面无需刷新即可更新内容,推动了Web2.0时代的到来。 在此期间,前端工程师的角色主要是模板工程师,负责...

    通过JavaScript+IFRAME实现页面分屏加载

    &lt;iframe src="http://example.com" width="400" height="300"&gt;&lt;/iframe&gt; ``` `src` 属性定义了要加载的页面URL,`width` 和 `height` 设置了IFRAME的尺寸。 ### 2. 分屏加载原理 分屏加载的核心思想是将页面拆分...

    让浏览器非阻塞加载javascript的几种方法小结

    通过JavaScript动态创建`&lt;script&gt;`元素,设置其`src`属性指向外部脚本,这样脚本可以在页面渲染过程中异步加载。这种方式允许并行加载多个脚本,但如果有依赖关系,需自行管理执行顺序。 3. **利用`&lt;iframe&gt;`加载**...

    HTML如何实现以form表单方式上传文件而不刷新页面.zip

    在HTML中,通常使用`&lt;form&gt;`标签来创建表单,包括文件上传...需要注意的是,这种方法仍然会有一个页面短暂的加载过程,因为`&lt;iframe&gt;`需要加载服务器的响应。不过,由于这个过程发生在后台,用户感知不到页面的刷新。

    自学使用HTML和CSS进行网站发布

    - **Ajax技术**:了解Ajax的工作原理及其在异步加载数据中的应用。 - **实际案例**:结合具体实例展示如何使用这些技术。 ##### 15. 处理框架和链接窗口(Working with Frames and Linked Windows) - **框架基础**...

    电子商务应用

    10. **性能优化**:通过异步加载资源(`&lt;link rel="preload"&gt;`)、延迟加载(`&lt;img loading="lazy"&gt;`)等HTML5特性,可以提升电子商务应用的页面加载速度,提高用户满意度。 通过熟练掌握这些HTML5特性,开发者可以...

    ecommerce

    8. **动态加载**:利用AJAX(Asynchronous JavaScript and XML)和`&lt;script&gt;`标签的`async`或`defer`属性,实现内容的异步加载,提升用户体验。 9. **支付集成**:虽然HTML本身不处理支付流程,但可以嵌入第三方...

    网页实现图片和PDF文件预览

    但为了在弹出窗口预览,我们可以使用jQuery创建一个新的`&lt;iframe&gt;`或者`&lt;object&gt;`元素,然后将图片内容插入其中。这样可以在新的窗口或模态对话框中显示图片。 4. **预览PDF**:预览PDF文件则复杂一些,因为浏览器...

    JS异步文件上传(兼容IE8+)

    同时,由于`iframe`的存在,可能会影响页面性能,因为`iframe`会加载整个响应,包括不必要的CSS和JavaScript资源。 总结来说,通过`iframe`实现的异步文件上传是一种兼容旧版浏览器(如IE8)的方法。虽然相比现代的...

    5月最新大厂前端高频核心面试题.pdf

    8. &lt;script&gt;标签的defer和async属性都可以让脚本异步加载,但async是完全异步加载并在加载完毕后立即执行,而defer则是等整个文档解析完毕后按照在文档中出现的顺序执行。 9. data-属性用于存储页面的自定义数据,...

    BAT2018年《80道前端面试题》.docx

    8. **iframe缺点**:iframe可能导致主页面Onload事件阻塞,影响页面加载性能;它与主页面共享连接池,可能导致并发限制问题。可以通过延迟加载或使用独立的请求来避免这些问题。 9. **cookies,sessionStorage和...

    lazyload.js实现图片异步延迟加载

    图片异步延迟加载,也称为懒加载(Lazy Loading),是一种优化网页性能的策略,它能够显著提高网页加载速度,减少用户等待时间,并节省网络带宽。在本文中,我们将深入探讨如何使用`lazyload.js`这个JavaScript库来...

Global site tag (gtag.js) - Google Analytics