iframe子頁面與父頁面在同域或不同域下的js通信
更新時(shí)間:2014年05月07日 09:04:04 作者:
根據(jù)iframe中src屬性是同域鏈接還是跨域鏈接,通信方式也不同,下面有個(gè)不錯(cuò)的示例,需要的朋友可以參考下
iframe子頁面與父頁面通信根據(jù)iframe中src屬性是同域鏈接還是跨域鏈接,通信方式也不同。
一、同域下父子頁面的通信
父頁面parent.html
<html>
<head>
<script type="text/javascript">
function say(){
alert("parent.html");
}
function callChild(){
myFrame.window.say();
myFrame.window.document.getElementById("button").value="調(diào)用結(jié)束";
}
</script>
</head>
<body>
<input id="button" type="button" value="調(diào)用child.html中的函數(shù)say()" onclick="callChild()"/>
<iframe name="myFrame" src="child.html"></iframe>
</body>
</html>
子頁面child.html
<html>
<head>
<script type="text/javascript">
function say(){
alert("child.html");
}
function callParent(){
parent.say();
parent.window.document.getElementById("button").value="調(diào)用結(jié)束";
}
</script>
</head>
<body>
<input id="button" type="button" value="調(diào)用parent.html中的say()函數(shù)" onclick="callParent()"/>
</body>
</html>
方法調(diào)用
父頁面調(diào)用子頁面方法:FrameName.window.childMethod();
子頁面調(diào)用父頁面方法:parent.window.parentMethod();
DOM元素訪問
獲取到頁面的window.document對(duì)象后,即可訪問DOM元素
注意事項(xiàng)
要確保在iframe加載完成后再進(jìn)行操作,如果iframe還未加載完成就開始調(diào)用里面的方法或變量,會(huì)產(chǎn)生錯(cuò)誤。判斷iframe是否加載完成有兩種方法:
1. iframe上用onload事件
2. 用document.readyState=="complete"來判斷
二、跨域父子頁面通信方法
如果iframe所鏈接的是外部頁面,因?yàn)榘踩珯C(jī)制就不能使用同域名下的通信方式了。
父頁面向子頁面?zhèn)鬟f數(shù)據(jù)
實(shí)現(xiàn)的技巧是利用location對(duì)象的hash值,通過它傳遞通信數(shù)據(jù)。在父頁面設(shè)置iframe的src后面多加個(gè)data字符串,然后在子頁面中通過某種方式能即時(shí)的獲取到這兒的data就可以了,例如:
1. 在子頁面中通過setInterval方法設(shè)置定時(shí)器,監(jiān)聽location.href的變化即可獲得上面的data信息
2. 然后子頁面根據(jù)這個(gè)data信息進(jìn)行相應(yīng)的邏輯處理
子頁面向父頁面?zhèn)鬟f數(shù)據(jù)
實(shí)現(xiàn)技巧就是利用一個(gè)代理iframe,它嵌入到子頁面中,并且和父頁面必須保持是同域,然后通過它充分利用上面第一種通信方式的實(shí)現(xiàn)原理就把子頁面的數(shù)據(jù)傳遞給代理iframe,然后由于代理的iframe和主頁面是同域的,所以主頁面就可以利用同域的方式獲取到這些數(shù)據(jù)。使用 window.top或者window.parent.parent獲取瀏覽器最頂層window對(duì)象的引用。
一、同域下父子頁面的通信
父頁面parent.html
復(fù)制代碼 代碼如下:
<html>
<head>
<script type="text/javascript">
function say(){
alert("parent.html");
}
function callChild(){
myFrame.window.say();
myFrame.window.document.getElementById("button").value="調(diào)用結(jié)束";
}
</script>
</head>
<body>
<input id="button" type="button" value="調(diào)用child.html中的函數(shù)say()" onclick="callChild()"/>
<iframe name="myFrame" src="child.html"></iframe>
</body>
</html>
子頁面child.html
復(fù)制代碼 代碼如下:
<html>
<head>
<script type="text/javascript">
function say(){
alert("child.html");
}
function callParent(){
parent.say();
parent.window.document.getElementById("button").value="調(diào)用結(jié)束";
}
</script>
</head>
<body>
<input id="button" type="button" value="調(diào)用parent.html中的say()函數(shù)" onclick="callParent()"/>
</body>
</html>
方法調(diào)用
父頁面調(diào)用子頁面方法:FrameName.window.childMethod();
子頁面調(diào)用父頁面方法:parent.window.parentMethod();
DOM元素訪問
獲取到頁面的window.document對(duì)象后,即可訪問DOM元素
注意事項(xiàng)
要確保在iframe加載完成后再進(jìn)行操作,如果iframe還未加載完成就開始調(diào)用里面的方法或變量,會(huì)產(chǎn)生錯(cuò)誤。判斷iframe是否加載完成有兩種方法:
1. iframe上用onload事件
2. 用document.readyState=="complete"來判斷
二、跨域父子頁面通信方法
如果iframe所鏈接的是外部頁面,因?yàn)榘踩珯C(jī)制就不能使用同域名下的通信方式了。
父頁面向子頁面?zhèn)鬟f數(shù)據(jù)
實(shí)現(xiàn)的技巧是利用location對(duì)象的hash值,通過它傳遞通信數(shù)據(jù)。在父頁面設(shè)置iframe的src后面多加個(gè)data字符串,然后在子頁面中通過某種方式能即時(shí)的獲取到這兒的data就可以了,例如:
1. 在子頁面中通過setInterval方法設(shè)置定時(shí)器,監(jiān)聽location.href的變化即可獲得上面的data信息
2. 然后子頁面根據(jù)這個(gè)data信息進(jìn)行相應(yīng)的邏輯處理
子頁面向父頁面?zhèn)鬟f數(shù)據(jù)
實(shí)現(xiàn)技巧就是利用一個(gè)代理iframe,它嵌入到子頁面中,并且和父頁面必須保持是同域,然后通過它充分利用上面第一種通信方式的實(shí)現(xiàn)原理就把子頁面的數(shù)據(jù)傳遞給代理iframe,然后由于代理的iframe和主頁面是同域的,所以主頁面就可以利用同域的方式獲取到這些數(shù)據(jù)。使用 window.top或者window.parent.parent獲取瀏覽器最頂層window對(duì)象的引用。
相關(guān)文章
javascript實(shí)現(xiàn)多張圖片左右無縫滾動(dòng)效果
本文主要介紹了javascript實(shí)現(xiàn)多張圖片左右無縫滾動(dòng)效果的實(shí)例。具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-03-03JS前端實(shí)現(xiàn)留言板功能的方法總結(jié)
留言板的主要使用場(chǎng)景是為用戶提供一個(gè)在網(wǎng)站或應(yīng)用上留言的平臺(tái),本文主要為大家介紹了四個(gè)常見的前端實(shí)現(xiàn)留言板功能的方法,希望對(duì)大家有所幫助2023-11-11由淺入深講解Javascript繼承機(jī)制與simple-inheritance源碼分析
Javascript語言對(duì)繼承實(shí)現(xiàn)的并不好,需要工程師自己去實(shí)現(xiàn)一套完整的繼承機(jī)制。下面我們由淺入深的系統(tǒng)掌握使用javascript繼承的技巧,對(duì)javascript繼承相關(guān)知識(shí)感興趣的朋友一起看看吧2015-12-12Echarts地圖實(shí)例詳解(地圖樣式、合并地圖、增加地圖)
ECharts是一個(gè)使用JavaScript實(shí)現(xiàn)的開源可視化庫,涵蓋各行業(yè)圖表,滿足各種需求,下面這篇文章主要給大家介紹了關(guān)于Echarts地圖的相關(guān)資料,包括地圖樣式、合并地圖、增加地圖,需要的朋友可以參考下2022-06-06JS實(shí)現(xiàn)仿新浪黃色經(jīng)典滑動(dòng)門效果代碼
這篇文章主要介紹了JS實(shí)現(xiàn)仿新浪黃色經(jīng)典滑動(dòng)門效果代碼,是一款非常簡(jiǎn)單的經(jīng)典鼠標(biāo)響應(yīng)滑動(dòng)切換效果,涉及JavaScript基于鼠標(biāo)事件動(dòng)態(tài)操作頁面元素的技巧,需要的朋友可以參考下2015-09-09JavaScript利用時(shí)間分片實(shí)現(xiàn)高性能渲染數(shù)據(jù)詳解
為了豐富我們的知識(shí)體系,我們有必要了解并清楚當(dāng)遇到大量數(shù)據(jù)時(shí),如何才能在不卡主頁面的情況下渲染數(shù)據(jù),以及其中背后的原理,本文介紹了如何使用時(shí)間分片的方式來渲染大量數(shù)據(jù),感興趣的可以了解下2023-05-05JavaScript 實(shí)現(xiàn)自己的安卓手機(jī)自動(dòng)化工具腳本(推薦)
這篇文章主要介紹了 JavaScript 實(shí)現(xiàn)自己的安卓手機(jī)自動(dòng)化工具腳本,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05