欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

嵌入式iframe子頁面與父頁面js通信的方法

 更新時(shí)間:2015年01月20日 11:27:03   投稿:shichen2014  
這篇文章主要介紹了嵌入式iframe子頁面與父頁面js通信的方法,實(shí)例分析了嵌入式iframe子頁面與父頁面js通信的常用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下

本文實(shí)例講述了嵌入式iframe子頁面與父頁面js通信的方法。分享給大家供大家參考。具體分析如下:

iframe框架中的頁面與主頁面之間的通信方式根據(jù)iframe中src屬性是同域鏈接還是跨域鏈接,有明顯不同的通信方式,同域下的數(shù)據(jù)交換和DOM元素互訪就簡(jiǎn)單的多了,而跨域的則需要一些巧妙的方式來實(shí)現(xiàn)通信。

一、同域下父子頁面的通信

父頁面 parent.html:

復(fù)制代碼 代碼如下:
<html>
<head>
<script type="text/javascript">
function say() {
alert("parent.html------>I'm at parent.html");
}
function callChild()
{
//document.frames["myFrame"].window.say();//只適用于ie瀏覽器
myFrame.window.say();
myFrame.window.document.getElementById("button").value="我變了";
}
</script>
</head>
<body>
<input 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--->I'm at child.html");
}
function callParent() {
parent.say();
parent.window.document.getElementsByName("myFrame")[0].style.height="100px";
}
</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元素訪問

根據(jù)FrameName.window得到了子窗口對(duì)象之后,再訪問其中的DOM元素就跟訪問同一頁面中的DOM元素沒區(qū)別了都可以通過

復(fù)制代碼 代碼如下:
document.getElementById(),document.getElementsByName()[index]
如:
復(fù)制代碼 代碼如下:
parent.window.document.getElementsByName("myFrame")[0];
myFrame.window.document.getElementById("button")
其中的window都是可以省略的。

注意事項(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 字符串(data就是你要傳遞的數(shù)據(jù)),然后在 子頁面 中通過某種方式能即時(shí)的獲取到這兒 data 就可以了,其實(shí)常用的一種方式就是:

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 C,它嵌入到 子頁面中,并且和父頁面必須保持是同域,然后我們通過它充分利用上面第一種通信方式的實(shí)現(xiàn)原理就能把 子頁面的數(shù)據(jù)傳遞給 iframeC,接下來的問題就是怎么讓iframeC把數(shù)據(jù)傳遞給主頁面A ,因?yàn)?,iframeC 和主頁面是同域的,所以它們之間傳遞數(shù)據(jù)就變得簡(jiǎn)單多了,屬于同域名下的通信問題了,如前面所討論的,在這里的可以使用一個(gè)經(jīng)常使用的屬性 window.top (也可以使用window.parent.parent),它返回對(duì)載入瀏覽器得最頂層 window 對(duì)象的引用,這樣我們就能直接條用父頁面中方法啦。

希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 如何用RxJS實(shí)現(xiàn)Redux Form

    如何用RxJS實(shí)現(xiàn)Redux Form

    這篇文章主要介紹了如何用RxJS實(shí)現(xiàn)Redux Form,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • javascript實(shí)現(xiàn)獲取瀏覽器版本、瀏覽器類型

    javascript實(shí)現(xiàn)獲取瀏覽器版本、瀏覽器類型

    這篇文章主要介紹了javascript實(shí)現(xiàn)獲取瀏覽器版本,javascript實(shí)現(xiàn)獲取瀏覽器類型兩大方面,對(duì)這方面感興趣的朋友可以參考一下
    2015-12-12
  • 小程序?qū)崿F(xiàn)輪播每次顯示三條數(shù)據(jù)

    小程序?qū)崿F(xiàn)輪播每次顯示三條數(shù)據(jù)

    這篇文章主要為大家詳細(xì)介紹了小程序?qū)崿F(xiàn)輪播每次顯示三條數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • js實(shí)現(xiàn)可旋轉(zhuǎn)的立方體模型

    js實(shí)現(xiàn)可旋轉(zhuǎn)的立方體模型

    這里給大家分享的是通過js腳本來控制頁面中的正方體轉(zhuǎn)動(dòng)特效,用戶可以點(diǎn)擊按鈕向右轉(zhuǎn)動(dòng),也可以向下轉(zhuǎn)動(dòng),結(jié)合自己的需求控制即可。效果非常棒,這里推薦給大家
    2016-10-10
  • JS彈出居中的DIV的代碼

    JS彈出居中的DIV的代碼

    一直都在想怎么樣使彈出的DIV能在任何時(shí)候都是居中顯示的,剛開始的時(shí)候是用CSS樣式直接定義好層的位置,但是當(dāng)頁面很長的時(shí)候,或是瀏覽器窗口大小不是固定的時(shí)候就不能正確的顯示,所以只好用JS來控制DIV的顯示位置。
    2008-06-06
  • 使用純javascript實(shí)現(xiàn)經(jīng)典掃雷游戲

    使用純javascript實(shí)現(xiàn)經(jīng)典掃雷游戲

    本文給大家分享的是個(gè)人剛開始學(xué)習(xí)javascript的時(shí)候?qū)懙姆聎indows經(jīng)典的掃雷游戲的代碼,當(dāng)時(shí)只是寫了下來,沒加注釋,這里補(bǔ)上,有需要的小伙伴可以參考下。
    2015-04-04
  • javascript &&和||運(yùn)算法的另類使用技巧

    javascript &&和||運(yùn)算法的另類使用技巧

    一直以為 && 和 || 這兩個(gè)偉大的運(yùn)算法只能在判斷表達(dá)式使用,也就是常在if語句使用,原來錯(cuò)了,它還可以運(yùn)用在簡(jiǎn)化選擇性執(zhí)行語句的操作,有點(diǎn)拗口,簡(jiǎn)單點(diǎn)也就是:操作執(zhí)行某條語句,不執(zhí)行某條語句。
    2009-11-11
  • 微信小程序web-view無法打開該頁面不支持打開的解決方法

    微信小程序web-view無法打開該頁面不支持打開的解決方法

    小程序現(xiàn)在日漸成熟,功能也越來越強(qiáng)大,我們今天來一起看看小程序跳轉(zhuǎn)的問題,下面這篇文章主要給大家介紹了關(guān)于微信小程序web-view無法打開該頁面不支持打開的解決方法,需要的朋友可以參考下
    2023-01-01
  • window.onerror()的用法與實(shí)例分析

    window.onerror()的用法與實(shí)例分析

    目前在做window.onerror時(shí)上報(bào)js錯(cuò)誤信息的事,整理下相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • JavaScript驗(yàn)證Email(3種方法)

    JavaScript驗(yàn)證Email(3種方法)

    這篇文章主要介紹了JavaScript驗(yàn)證Email的3種方法,需要的朋友可以參考下
    2015-09-09

最新評(píng)論