js—iframe父子頁面間通信

iframe子頁面與父頁面通信根據(jù)iframe中src屬性是同域鏈接還是跨域鏈接寝凌,通信方式也不同俱箱。

一、同域下父子頁面通信

父頁面 parent.html

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
    <iframe id="box2" name="myframe" src="./iframe.html?4" frameborder="0"></iframe>
    <script>
        window.onload = function () {
            // 操作父頁面
            myframe.window.document.getElementById('box').onclick = function () {
                document.getElementById('box2').style.display='none'
            }
        }
    </script>
</body>
</html>

子頁面 child.html

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
    <div id="box" style="height: 100px;background-color: red;"></div>
    <!--<script>
        // 操作子頁面
        document.getElementById('box').onclick = function () {
            parent.window.document.getElementById('box2').style.display='none'
        }
    </script>-->
</body>
</html>

方法調(diào)用

  1. 父頁面調(diào)用子頁面方法:FrameName.window.childMethod();
  2. 子頁面調(diào)用父頁面方法:parent.window.parentMethod();

DOM元素訪問
獲取到頁面的window.docunment對象之后瓷耙,就可以訪問頁面的元素了
注意
要確保在iframe加載完成后再進(jìn)行操作剿另,如果iframe還未加載完成就開始調(diào)用里面的方法或變量,會產(chǎn)生錯誤逛钻。判斷iframe是否加載完成有兩種方法:

  1. iframe上用onload事件
  2. 用document.readyState=="complete"來判斷

二僚焦、跨域父子頁面通信方法

如果iframe所鏈接的是外部頁面,因為安全機(jī)制就不能使用同域名下的通信方式了曙痘。

父頁面向子頁面?zhèn)鬟f數(shù)據(jù)

實現(xiàn)的技巧是利用location對象的hash值芳悲,通過它傳遞通信數(shù)據(jù)。在父頁面設(shè)置iframe的src后面多加個data字符串边坤,然后在子頁面中通過某種方式能即時的獲取到這兒的data就可以了名扛,例如:

  1. 在子頁面中通過setInterval方法設(shè)置定時器,監(jiān)聽location.href的變化即可獲得上面的data信息
  2. 然后子頁面根據(jù)這個data信息進(jìn)行相應(yīng)的邏輯處理

子頁面向父頁面?zhèn)鬟f數(shù)據(jù)

實現(xiàn)技巧就是利用一個代理iframe茧痒,它嵌入到子頁面中肮韧,并且和父頁面必須保持是同域,然后通過它充分利用上面第一種通信方式的實現(xiàn)原理就把子頁面的數(shù)據(jù)傳遞給代理iframe旺订,然后由于代理的iframe和主頁面是同域的弄企,所以主頁面就可以利用同域的方式獲取到這些數(shù)據(jù)。使用 window.top或者window.parent.parent獲取瀏覽器最頂層window對象的引用耸峭。

轉(zhuǎn)自:https://www.cnblogs.com/sydeveloper/p/3712863.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末桩蓉,一起剝皮案震驚了整個濱河市淋纲,隨后出現(xiàn)的幾起案子劳闹,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件本涕,死亡現(xiàn)場離奇詭異业汰,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)菩颖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進(jìn)店門样漆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人晦闰,你說我怎么就攤上這事放祟。” “怎么了呻右?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵跪妥,是天一觀的道長。 經(jīng)常有香客問我声滥,道長眉撵,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任落塑,我火速辦了婚禮纽疟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘憾赁。我一直安慰自己污朽,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布龙考。 她就那樣靜靜地躺著膘壶,像睡著了一般。 火紅的嫁衣襯著肌膚如雪洲愤。 梳的紋絲不亂的頭發(fā)上颓芭,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天,我揣著相機(jī)與錄音柬赐,去河邊找鬼亡问。 笑死,一個胖子當(dāng)著我的面吹牛肛宋,可吹牛的內(nèi)容都是我干的州藕。 我是一名探鬼主播,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼酝陈,長吁一口氣:“原來是場噩夢啊……” “哼床玻!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起沉帮,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤锈死,失蹤者是張志新(化名)和其女友劉穎贫堰,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體待牵,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡其屏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了缨该。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片偎行。...
    茶點故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖贰拿,靈堂內(nèi)的尸體忽然破棺而出蛤袒,到底是詐尸還是另有隱情,我是刑警寧澤膨更,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布汗盘,位于F島的核電站,受9級特大地震影響询一,放射性物質(zhì)發(fā)生泄漏隐孽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一健蕊、第九天 我趴在偏房一處隱蔽的房頂上張望菱阵。 院中可真熱鬧,春花似錦缩功、人聲如沸晴及。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽虑稼。三九已至,卻和暖如春势木,著一層夾襖步出監(jiān)牢的瞬間蛛倦,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工啦桌, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留溯壶,地道東北人。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓甫男,卻偏偏與公主長得像且改,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子板驳,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,979評論 2 355

推薦閱讀更多精彩內(nèi)容

  • iframe框架中的頁面與主頁面之間的通信方式根據(jù)iframe中src屬性是同域鏈接還是跨域鏈接又跛,有明顯不同的通信...
    daae49c52428閱讀 795評論 0 0
  • 元素會創(chuàng)建包含另外一個文檔的內(nèi)聯(lián)框架(即行內(nèi)框架); 一若治、align 屬性(不贊成) align屬性規(guī)定ifram...
    puxiaotaoc閱讀 19,731評論 0 14
  • 1. 什么是跨域慨蓝? 跨域一詞從字面意思看感混,就是跨域名嘛,但實際上跨域的范圍絕對不止那么狹隘菌仁。具體概念如下:只要協(xié)議...
    w_zhuan閱讀 518評論 0 0
  • 1. 什么是跨域? 跨域一詞從字面意思看静暂,就是跨域名嘛济丘,但實際上跨域的范圍絕對不止那么狹隘。具體概念如下:只要協(xié)議...
    他在發(fā)呆閱讀 822評論 0 0
  • 原文連接:http://www.cnblogs.com/2050/p/3191744.html js中幾種實用的跨...
    小豆soybean閱讀 334評論 0 3