本文实例讲述了js检测iframe是否加载完成的方法。分享给大家供大家参考,具体如下:
这里是继上一篇《js实现iframe框架取值的方法(兼容IE,firefox,chrome等)》的扩展应用:
应用场景:iframe个人感觉最独特的应用之一就是配合P3P协议可以实现跨域写入cookie(好象除此之外,还没找到更有效的办法),但是有时候我们不知道这个iframe页面是否执行完毕,有没有办法判断iframe里的页面是否load完成了呢?
iframe1.html:
<html> <head> <title>框架内页</title> </head> <body> <div> <input id="txt" name="txt" type="text" value="3秒钟后这里会变成ok" /> </div> <script type="text/javascript"> setTimeout("SetValue()",3000); function SetValue(){ document.getElementById("txt").value="ok"; } </script> </body> </html>
iframe2.html:
<html> <head> <title>框架内页</title> </head> <body> <div> <input id="txt" name="txt" type="text" value="6秒钟后这里会变成ok" /> </div> <script type="text/javascript"> setTimeout("SetValue()",6000); function SetValue(){ document.getElementById("txt").value="ok"; } </script> </body> </html>
index.html:
<html> <head> <title>检测本页中的所有iframe是否加载完成</title> <script type="text/javascript"> //得取iframe中的某个html控件值 function getIframeControlValue(iframeId,controlId){ var ofrm = document.getElementById(iframeId).document; if (ofrm==undefined) { ofrm = document.getElementById(iframeId).contentWindow.document; var ff = ofrm1.getElementById(controlId).value; return ff; } else { var ie = document.frames[iframeId].document.getElementById(controlId).value; return ie; } } //检测所有的iframe是否"加载"完成 function fnLoadOk(){ var b = true; for(var i=1;i<=2;i++){ if (getIframeControlValue("frame" + i,"txt")=="ok"){ b = b && true; } else { b = b && false; } } return b; } //设置回答显示区的值 function setValue(str){ if (str!=null && str.length>0){ document.getElementById("result").innerHTML = "<span style='color:red'>" + new Date().toLocaleString() + " " + str + "</span>"; } else{ document.getElementById("result").innerHTML = "<span style='color:green'>" + new Date().toLocaleString() + " 正在加载" + "</span>"; } } var _check = setInterval("t()",500);//每隔0.5秒检查一次 function t(){ if (fnLoadOk()){ clearInterval(_check);//加载完成后,清除定时器 setValue("加载完成!"); } else{ setValue(); } } </script> </head> <body> <h3>检测本页中的iframe是否加载完成</h3> <iframe name="frame1" id="frame1" src="/UploadFiles/2021-04-02/iframe1.html">值得注意的是:本文中的示例是放在按钮click事件中检测的,如果打算页面一打开就开始检测,一定要放在index.html页body的onload事件中,否则会出异常(原因是index.html尚未加载完成,这时就急着获取框架的内容,得到的是undefined或null)
希望本文所述对大家JavaScript程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。