js下判断 iframe 是否加载完成的完美方法


Posted in Javascript onOctober 26, 2010

采用的方法很类似:

var iframe = document.createElement("iframe"); 
iframe.src = "https://3water.com"; if (!/*@cc_on!@*/0) { //if not IE 
iframe.onload = function(){ 
alert("Local iframe is now loaded."); 
}; 
} else { 
iframe.onreadystatechange = function(){ 
if (iframe.readyState == "complete"){ 
alert("Local iframe is now loaded."); 
} 
}; 
} 
document.body.appendChild(iframe);

最近, Nicholas C. Zakas 文章《Iframes, onload, and document.domain》的评论中 Christopher 提供了一个新的判断方法(很完美):
var iframe = document.createElement("iframe"); 
iframe.src = "http://sc.3water.com"; 
if (iframe.attachEvent){ 
iframe.attachEvent("onload", function(){ 
alert("Local iframe is now loaded."); 
}); 
} else { 
iframe.onload = function(){ 
alert("Local iframe is now loaded."); 
}; 
} 
document.body.appendChild(iframe);

几点补充说明:

IE 支持 iframe 的 onload 事件,不过是隐形的,需要通过 attachEvent 来注册。
第二种方法比第一种方法更完美,因为 readystatechange 事件相对于 load 事件有一些潜在的问题。

Javascript 相关文章推荐
学习YUI.Ext 第六天--关于树TreePanel(Part 1)
Mar 10 Javascript
Date对象格式化函数代码
Jul 17 Javascript
这些年、我收集的JQuery代码小结
Aug 01 Javascript
11个用于提高排版水平的基于jquery的文字效果插件
Sep 14 Javascript
浅谈JavaScript中定义变量时有无var声明的区别
Aug 18 Javascript
BootStrap实现响应式布局导航栏折叠隐藏效果(在小屏幕、手机屏幕浏览时自动折叠隐藏)
Nov 30 Javascript
微信小程序 列表的上拉加载和下拉刷新的实现
Apr 01 Javascript
JavaScript实现二维坐标点排序效果
Jul 18 Javascript
JS 实现分页打印功能
May 16 Javascript
详解vue后台系统登录态管理
Apr 02 Javascript
javascript使用链接跨域下载图片
Nov 01 Javascript
使用node-media-server搭建一个简易的流媒体服务器
Jan 20 Javascript
Javascript下判断是否为闰年的Datetime包
Oct 26 #Javascript
基于jquery的给文章加入关键字链接
Oct 26 #Javascript
EasyUi tabs的高度与宽度根据IE窗口的变化自适应代码
Oct 26 #Javascript
自写的一个jQuery圆角插件
Oct 26 #Javascript
jQuery获取地址栏参数插件(模仿C#)
Oct 26 #Javascript
自制轻量级仿jQuery.boxy对话框插件代码
Oct 26 #Javascript
jquery ui resizable bug解决方法
Oct 26 #Javascript
You might like
mysql_fetch_assoc和mysql_fetch_row的功能加起来就是mysql_fetch_array
2007/01/15 PHP
php 网页游戏开发入门教程一(webgame+design)
2009/10/26 PHP
PHP人民币金额数字转中文大写的函数代码
2013/02/27 PHP
PHP中的str_repeat函数在JavaScript中的实现
2013/09/16 PHP
JavaScript 封装一个tab效果源码分享
2015/09/15 Javascript
JS组件Form表单验证神器BootstrapValidator
2016/01/26 Javascript
jQuery模拟select实现下拉菜单功能
2016/06/20 Javascript
AngularJS 中的事件详解
2016/07/28 Javascript
移动端使用localStorage缓存Js和css文的方法(web开发)
2016/09/20 Javascript
自己封装的一个简单的倒计时功能实例
2016/11/23 Javascript
AngularJS自定义指令之复制指令实现方法
2017/05/18 Javascript
JavaScript 中Date对象的格式化代码方法汇总
2017/09/06 Javascript
详解用函数式编程对JavaScript进行断舍离
2017/09/18 Javascript
web前端vue filter 过滤器
2018/01/12 Javascript
javascript设计模式 ? 解释器模式原理与用法实例分析
2020/04/17 Javascript
Node.js API详解之 util模块用法实例分析
2020/05/09 Javascript
vue页面跳转实现页面缓存操作
2020/07/22 Javascript
[37:03]完美世界DOTA2联赛PWL S3 INK ICE vs GXR 第二场 12.16
2020/12/18 DOTA
Python使用MySQLdb for Python操作数据库教程
2014/10/11 Python
Python简单定义与使用二叉树示例
2018/05/11 Python
解决python nohup linux 后台运行输出的问题
2018/05/11 Python
Django配置celery(非djcelery)执行异步任务和定时任务
2018/07/16 Python
使用Python实现微信提醒备忘录功能
2018/12/04 Python
如何使用python爬虫爬取要登陆的网站
2019/07/12 Python
python xlwt如何设置单元格的自定义背景颜色
2019/09/03 Python
Python 读取位于包中的数据文件
2020/08/07 Python
澳大利亚领先的在线美容商城:Adore Beauty
2017/04/14 全球购物
Bose美国官网:购买Bose耳机和音箱
2019/03/10 全球购物
Jacques Lemans德国:奥地利钟表品牌
2019/12/26 全球购物
C++:memset ,memcpy和strcpy的根本区别
2013/04/27 面试题
老总助理工作岗位职责
2014/02/06 职场文书
村干部培训班主持词
2014/03/28 职场文书
加强作风建设演讲稿
2014/10/24 职场文书
研究生给导师的自荐信
2015/03/06 职场文书
九年级化学教学反思
2016/02/22 职场文书
2019企业文化管理制度范本!
2019/08/06 职场文书