基于JS判斷iframe是否加載成功的方法(多種瀏覽器)
推薦閱讀:
在項(xiàng)目中經(jīng)常要?jiǎng)討B(tài)添加iframe,然后再對(duì)添加的iframe進(jìn)行相關(guān)操作,而往往iframe還沒添加完呢,后邊的代碼就已經(jīng)執(zhí)行完了,所以有些你寫的東西根本沒有顯示出來。這時(shí),我們就要考慮是否可以等iframe加載完后再執(zhí)行后邊的操作,當(dāng)然,各種瀏覽器早就為我們考慮到啦,看下面:
ie瀏覽器
IE的每個(gè)elem節(jié)點(diǎn)都會(huì)擁有一個(gè)onreadystatechange事件,這個(gè)事件每次在elem內(nèi)容發(fā)送變化的時(shí)候觸發(fā),比如內(nèi)容正在載入loading會(huì)觸發(fā),內(nèi)容載入完畢loaded會(huì)觸發(fā),內(nèi)容載入成功complete會(huì)觸發(fā),這個(gè)函數(shù)還需要配合readyState,這是ie上每個(gè)elem都擁有的屬性,用來查看每次觸發(fā)時(shí)候的狀態(tài)。
//先為iframe 添加一個(gè) onreadystatechange iframe.attachEvent("onreadystatechange", function(){ //此事件在內(nèi)容沒有被載入時(shí)候也會(huì)被觸發(fā),所以我們要判斷狀態(tài) //有時(shí)候會(huì)比較怪異 readyState狀態(tài)會(huì)跳過 complete 所以我們loaded狀態(tài)也要判斷 if(iframe.readyState === "complete" || iframe.readyState == "loaded"){ //代碼能執(zhí)行到這里說明已經(jīng)載入成功完畢了 //要清除掉事件 iframe.detachEvent( "onreadystatechange", arguments.callee); //這里是回調(diào)函數(shù) } });
其他瀏覽器(Firefox,Opera,chrome等 )
在其他非IE的瀏覽器上 Firefox,Opera,chrome等 iframe 都會(huì)擁有一個(gè) onload 事件,此事件只要觸發(fā)就說名內(nèi)容已經(jīng)加載完畢。
iframe.addEventListener( "load", function(){ //代碼能執(zhí)行到這里說明已經(jīng)載入成功完畢了 this.removeEventListener( "load", arguments.call, false); //這里是回調(diào)函數(shù) }, false);
綜合一下
if(iframe.attachEvent){ iframe.attachEvent("onreadystatechange", function() { //此事件在內(nèi)容沒有被載入時(shí)候也會(huì)被觸發(fā),所以我們要判斷狀態(tài) //有時(shí)候會(huì)比較怪異 readyState狀態(tài)會(huì)跳過 complete 所以我們loaded狀態(tài)也要判斷 if (iframe.readyState === "complete" || iframe.readyState == "loaded") { //代碼能執(zhí)行到這里說明已經(jīng)載入成功完畢了 //要清除掉事件 iframe.detachEvent("onreadystatechange", arguments.callee); //這里是回調(diào)函數(shù) } }); }else{ iframe.addEventListener("load", function() { //代碼能執(zhí)行到這里說明已經(jīng)載入成功完畢了 this.removeEventListener("load", arguments.call, false); //這里是回調(diào)函數(shù) }, false); }
注意:上面的函數(shù)必須放在 iframe 被appendChild到body后,否則不會(huì)被觸發(fā)
以上內(nèi)容是小編給大家介紹的JS判斷iframe是否加載成功的方法,希望對(duì)大家有所幫助!
相關(guān)文章
JavaScript讀取中文cookie時(shí)的亂碼問題的解決方法
讀取中文cookie時(shí)出現(xiàn)亂碼,下面是具體的解決方法,大家以后使用過程中,盡量不要用中文。2009-10-10深入理解JavaScript系列(13) This? Yes,this!
在這篇文章里,我們將討論跟執(zhí)行上下文直接相關(guān)的更多細(xì)節(jié)。討論的主題就是this關(guān)鍵字。實(shí)踐證明,這個(gè)主題很難,在不同執(zhí)行上下文中this的確定經(jīng)常會(huì)發(fā)生問題2012-01-01JS動(dòng)態(tài)修改圖片的URL(src)的方法
這篇文章主要介紹了JS動(dòng)態(tài)修改圖片的URL(src)的方法,涉及javascript操作圖片src屬性的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04JavaScript變量作用域及內(nèi)存問題實(shí)例分析
這篇文章主要介紹了JavaScript變量作用域及內(nèi)存問題,結(jié)合實(shí)例形式分析了javascript全局變量、局部變量、塊級(jí)作用域等概念及內(nèi)存優(yōu)化問題相關(guān)操作技巧,需要的朋友可以參考下2019-06-06JavaScript實(shí)現(xiàn)移動(dòng)端拖動(dòng)元素
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)移動(dòng)端拖動(dòng)元素,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11JS實(shí)現(xiàn)的相冊(cè)圖片左右滾動(dòng)完整實(shí)例
這篇文章主要介紹了JS實(shí)現(xiàn)的相冊(cè)圖片左右滾動(dòng)效果,結(jié)合完整實(shí)例形式分析了javascript事件觸發(fā)與頁面元素屬性動(dòng)態(tài)變換的相關(guān)操作技巧,需要的朋友可以參考下2016-11-11基于JavaScript實(shí)現(xiàn)大文件上傳后端代碼實(shí)例
這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)大文件上傳后端代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08