茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    嵌入式iframe子頁面與父頁面js通信的方法
    來源:易賢網(wǎng) 閱讀:1144 次 日期:2015-03-25 11:31:52
    溫馨提示:易賢網(wǎng)小編為您整理了“嵌入式iframe子頁面與父頁面js通信的方法”,方便廣大網(wǎng)友查閱!

    這篇文章主要介紹了嵌入式iframe子頁面與父頁面js通信的方法,實例分析了嵌入式iframe子頁面與父頁面js通信的常用技巧,非常具有實用價值,需要的朋友可以參考下

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

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

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

    父頁面 parent.html:

    代碼如下:

    <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:

    代碼如下:

    <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得到了子窗口對象之后,再訪問其中的DOM元素就跟訪問同一頁面中的DOM元素沒區(qū)別了都可以通過

    代碼如下:

    document.getElementById(),document.getElementsByName()[index]

    如:

    代碼如下:

    parent.window.document.getElementsByName("myFrame")[0];

    myFrame.window.document.getElementById("button")

    其中的window都是可以省略的。

    注意事項

    要確保在Iframe加載完成后再進行操作,如果Iframe還未加載完成就開始調(diào)用里面的方法或變量,無疑會產(chǎn)生錯誤。判斷Iframe是否加載完畢有兩種方法:

    1.在Iframe上用onload事件;

    2.用document.readyState=="complete"來判斷

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

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

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

    實現(xiàn)的技巧就是利用 location 對象的 hash 值,通過它傳遞通信數(shù)據(jù),我們只需要在父頁面設置 iframe的 src 后面多加個#data 字符串(data就是你要傳遞的數(shù)據(jù)),然后在 子頁面 中通過某種方式能即時的獲取到這兒 data 就可以了,其實常用的一種方式就是:

    1. 在 子頁面 中通過 setInterval 方法設置定時器, 監(jiān)聽 location.href 的變化即可獲得上面的 data 信息

    2. 然后 子頁面 就能根據(jù)這個 data 信息進行相應的邏輯處理。

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

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

    希望本文所述對大家的javascript程序設計有所幫助。

    更多信息請查看IT技術專欄

    更多信息請查看腳本欄目
    易賢網(wǎng)手機網(wǎng)站地址:嵌入式iframe子頁面與父頁面js通信的方法

    2026國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)