JS如何對(duì)Iframe內(nèi)外頁(yè)面進(jìn)行操作總結(jié)
在iframe外獲取iframe里的內(nèi)容
方式一
通過(guò)contentWindow和contentDocument這兩個(gè)API:
var iframe = document.getElementById("iframe1");
var iwindow = iframe.contentWindow;
var idoc = iwindow.document;
var idocument = iframe.contentDocument;
console.log("window",iwindow);//獲取iframe的window對(duì)象
console.log("document",idoc); //獲取iframe的document
console.log("html",idoc.documentElement);//獲取iframe的html
其中iframe.contentWindow可以獲取iframe的window對(duì)象,iframe.contentDocument可以獲取iframe的document對(duì)象。
方式二
結(jié)合Name屬性,通過(guò)window提供的frames獲取:
<iframe src ="/index.html" id="ifr1" name="ifr2" scrolling="yes">
<p>Your browser does not support iframes.</p>
</iframe>
<script type="text/javascript">
console.log(window.frames['ifr2'].window);
console.dir(document.getElementById("iframe").contentWindow);
</script>
在iframe內(nèi)獲取iframe外的內(nèi)容
window.parent 獲取上一級(jí)的window對(duì)象,如果還是iframe則是該iframe的window對(duì)象
window.top 獲取最頂級(jí)容器的window對(duì)象,即,就是你打開(kāi)頁(yè)面的文檔

在iframe中調(diào)用父頁(yè)面中定義的方法和變量
window.parent.window.parentMethod(); window.parent.window.parentValue;
在父頁(yè)面操作iframe子頁(yè)面的方法和變量
window.frames["iframe_Name"].window.childMethod(); window.frames["iframe_Name"].window.childValue;
總結(jié)
在使用Iframe時(shí)還需要注意以下兩點(diǎn):
- 要確保在iframe加載完成后再進(jìn)行操作,如果iframe還未加載完成就開(kāi)始調(diào)用里面的方法或變量,會(huì)產(chǎn)生錯(cuò)誤;
- 如果iframe所鏈接的是外部頁(yè)面,因?yàn)榘踩珯C(jī)制不能使用同域名下的通信方式;
判斷iframe加載完成
iframe.onload = function() {
// TODO
}
不同域通信
父頁(yè)面向子頁(yè)面?zhèn)鬟f數(shù)據(jù)
利用location對(duì)象的hash值,通過(guò)它傳遞通信數(shù)據(jù)。在父頁(yè)面設(shè)置iframe的src后面多加個(gè)data字符串,然后在子頁(yè)面中通過(guò)某種方式能即時(shí)的獲取到這兒的data。
子頁(yè)面向父頁(yè)面?zhèn)鬟f數(shù)據(jù)
利用一個(gè)代理iframe,它嵌入到子頁(yè)面中,并且和父頁(yè)面必須保持是同域,然后通過(guò)它充分利用上面同域通信方式的實(shí)現(xiàn)原理,把子頁(yè)面的數(shù)據(jù)傳遞給代理iframe,然后由于代理的iframe和主頁(yè)面是同域的,所以主頁(yè)面就可以利用同域的方式獲取到這些數(shù)據(jù)。
到此這篇關(guān)于JS如何對(duì)Iframe內(nèi)外頁(yè)面進(jìn)行操作的文章就介紹到這了,更多相關(guān)JS對(duì)Iframe頁(yè)面操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
layui內(nèi)置模塊layim發(fā)送圖片添加加載動(dòng)畫(huà)的方法
今天小編就為大家分享一篇layui內(nèi)置模塊layim發(fā)送圖片添加加載動(dòng)畫(huà)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
javascript實(shí)現(xiàn)Email郵件顯示與刪除功能
這篇文章主要介紹了javascript實(shí)現(xiàn)Email郵件顯示與刪除功能,需要的朋友可以參考下2015-11-11
js判斷一個(gè)對(duì)象是數(shù)組(函數(shù))的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于利用js如何判斷一個(gè)對(duì)象是數(shù)組(函數(shù))的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JS具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
淺談JavaScript構(gòu)造樹(shù)形結(jié)構(gòu)的一種高效算法
這篇文章主要介紹了JavaScript構(gòu)造樹(shù)形結(jié)構(gòu)的一種高效算法,對(duì)算法感興趣的同學(xué),可以參考下2021-05-05
JS圖片懶加載的優(yōu)點(diǎn)及實(shí)現(xiàn)原理
這篇文章主要介紹了JS圖片懶加載的優(yōu)點(diǎn)及實(shí)現(xiàn)原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01
IE和Firefox的Javascript兼容性總結(jié)[推薦收藏]
長(zhǎng)久以來(lái)JavaScript兼容性一直是Web開(kāi)發(fā)者的一個(gè)主要問(wèn)題。在正式規(guī)范、事實(shí)標(biāo)準(zhǔn)以及各種實(shí)現(xiàn)之間的存在的差異讓許多開(kāi)發(fā)者日夜煎熬2011-10-10
javaScript window.event.keyCode 集合與測(cè)試方法
javaScript window.event.keyCode 集合,對(duì)于事件的代碼獲取可以用腳本監(jiān)聽(tīng)來(lái)實(shí)現(xiàn)。2010-05-05

