亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Javascript iframe交互并兼容各種瀏覽器的解決方法

 更新時間:2016年07月12日 10:22:20   作者:嗑瓜子兒gf  
這篇文章主要介紹了Javascript iframe交互并兼容各種瀏覽器的解決方法的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

在Web前端開發(fā)中,我們經(jīng)常會用到iframe這個控件。

但是這個控在內、外交互時,往往各個瀏覽器所用的關鍵字不同,很是麻煩,為了能夠得到子iframe中的window對象,各家瀏覽器有著各家的指定,有的是window,有的是contentWindow等等也許還有我們不知道的。

但是從子頁面訪問父層頁面,其本上大家都是window.parent就可以了。

那么通過這個特征,我們可以在子頁面中,把自身的window對象傳遞給父頁面就可以了,這樣父頁面就很輕松的訪問子頁面,再也不用靠慮如何從iframe對象上得到window對象了。

二話不說,我們先看代碼:

父頁面代碼:

window.iframeWindow = null;
function frameReady(subWindow){
window.iframeWindow = subWindow; //賦值
}; 
<iframe src = "xx" ></iframe> 

子頁面代碼:

$(function(){
window.parent.frameReady(window);
}); 

通過上面簡單的代碼,就可以在父頁面中訪問iframeWindow對象,直接得到了子頁面的window對象,非常無腦也非常好用。

如果我有多個iframe該怎么辦呢?

這種情況會稍微復雜一點,但是沒關系。我們想繼續(xù)使用上面的方案,就分析一下現(xiàn)狀:

1.我們應該會需要一個類似iframeWindows的集合對象,用于管理所有子頁面的window對象。

2.每個子頁面在調用parent.frameReady時,必須靠訴父頁面一個唯一名稱,使得我們可以在父頁面中對各個iframe進行精確訪問

那么這下就簡單了,子頁面要做的事,無非就是一個名稱、編號啥的,我們來看代碼

window.subWindowName = "HelloWorldWindow";
$(function(){
window.parent.frameReady(window.subWindowName, window);
}); 

那么父頁面要做的事就是重構frameReady并增加一個參數(shù)

window.iframeWindows = {}; //這里變成了一個對象
function frameReady(name, window){
window.iframeWindows[name] = window;
};
function getSubWindow(name){
return window.iframeWindows[name];
}

總結:

通過這種方案構建的頁面存在以下優(yōu)點:

1.父子頁面的交互僅依賴于parent關鍵字(而以前的方式中,不僅依賴parent,還要依賴contentWindow、window等其它不確定關鍵字,最重要的是parent的支持還是非常好的)

2.window對象統(tǒng)一化,減少了每次使用時再請求的引用鏈,提高了運行的速度

3.最重要的一點:就是代碼寫起來輕松多了。

以上所述是小編給大家介紹的Javascript iframe交互并兼容各種瀏覽器的解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • electron 如何將任意資源打包的方法步驟

    electron 如何將任意資源打包的方法步驟

    這篇文章主要介紹了electron 如何將任意資源打包的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • Wordpress ThickBox 點擊圖片顯示下一張圖的修改方法

    Wordpress ThickBox 點擊圖片顯示下一張圖的修改方法

    Wordpress自帶的ThickBox特效中,單擊圖片會調用 tb_remove 以關閉特效窗口,現(xiàn)將修改其動作為顯示下一張圖。
    2010-12-12
  • javascript代碼實現(xiàn)簡易計算器

    javascript代碼實現(xiàn)簡易計算器

    這篇文章主要為大家詳細介紹了javascript代碼實現(xiàn)簡易計算器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • JavaScript中的內存泄漏的原因

    JavaScript中的內存泄漏的原因

    本文主要介紹了聊一聊JavaScript中的內存泄漏,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • 最新熱門腳本Autojs源碼分享

    最新熱門腳本Autojs源碼分享

    AutoJS 是基于一個標準字典庫的文本輸入自動完成 JavaScript 庫。Auto.js 是使用純 JS 實現(xiàn)的,沒有任務外部依賴,大小僅僅 6kb,本文給大家分享最新熱門腳本Autojs源碼,感興趣的朋友一起看看吧
    2021-05-05
  • javascript十六進制及二進制轉化的方法

    javascript十六進制及二進制轉化的方法

    這篇文章主要介紹了javascript十六進制及二進制轉化的方法,涉及javascript中toString方法的使用技巧,需要的朋友可以參考下
    2015-05-05
  • 微信小程序獲取位置展示地圖并標注信息的實例代碼

    微信小程序獲取位置展示地圖并標注信息的實例代碼

    這篇文章主要介紹了微信小程序獲取位置展示地圖并標注信息的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • JS 邏輯判斷不要只知道用 if-else 和 switch條件判斷(小技巧)

    JS 邏輯判斷不要只知道用 if-else 和 switch條件判斷(小技巧)

    這篇文章主要介紹了JS 邏輯判斷不要只知道用 if-else 和 switch,在一些邏輯復雜度的增加,代碼中的 if/else 和 switch 會越來越臃腫。本文將帶你嘗試寫出更優(yōu)雅的判斷邏輯,需要的朋友可以參考下
    2020-05-05
  • javascript實現(xiàn)劃詞標記+劃詞搜索功能

    javascript實現(xiàn)劃詞標記+劃詞搜索功能

    javascript實現(xiàn)劃詞標記+劃詞搜索功能...
    2007-03-03
  • ES6解構賦值實例詳解

    ES6解構賦值實例詳解

    這篇文章主要介紹了ES6解構賦值,結合實例形式較為詳細的分析了ES6結構賦值的基本概念、原理與使用方法,需要的朋友可以參考下
    2017-10-10

最新評論