亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

關于Javascript與iframe的那些事兒

2019-11-20 22:34:24
字體:
來源:轉載
供稿:網友
嵌入 iframe 的頁面,父頁面與子頁面均可以很輕松的在同域或跨子域的情況下進行讀寫操作;在完全不同域的情況下,也可以通過更改 hash 的方式進行通信。下面我在九個不同(版本的)瀏覽器中對此進行數據傳輸與更改的兼容性測試。
同域或跨子域讀寫操作 iframe 里的內容
父頁面讀寫操作子頁面:
復制代碼 代碼如下:

<iframe id="test-iframe" name="test-iframe" src="child.html" scrolling="no" frameborder="0"></iframe>
<script>
window.onload = function () {
  /*
   *  下面兩種獲取節點內容的方式都可以。
   *  由于 IE6, IE7 不支持 contentDocument 屬性,所以此處用了通用的
   *  window.frames["iframe Name"] or window.frames[index]
   */
  var d = window.frames["test-iframe"].document;
  d.getElementsByTagName('h1')[0].innerHTML = 'pp';
  alert(d.getElementsByTagName('h1')[0].firstChild.data);
}
</script>

注:在請務必通過 window.onload 方法訪問 iframe 中的節點,否則瀏覽器會提示錯誤-拒絕訪問。在 IE8, Firefox3.6, Opera11 下在DOMReady 時也可以訪問 iframe 中的節點。
子頁面讀寫操作父頁面:
復制代碼 代碼如下:

<script>
  parent.document.getElementsByTagName('h1')[0].innerHTML = 'pp';
  alert(parent.document.getElementsByTagName('h1')[0].firstChild.data);
</script>

小結:
•1 測試通過 IE6, IE7, IE8, Firefox2.0, Firefox3.0, Firefox3.6, Chrome8, Opera11, Safari5.
•2 查閱資料得出 document.getElementById(‘id name').contentDocument 全等于 window.frames["iframe Name"].document.
•3 跨子域時,需要在父頁面和子頁面 JS 中分別加上 document.domain = 'xxx.com';
跨域操作 iframe 里內容
當兩個網頁所在域不同時,要實現數據的互相調用,只能通過 JS 改變 location 對象的 hash 屬性的值來做到互相通信。
父頁面:
復制代碼 代碼如下:

<iframe id="test-iframe" src="http://www.yyy.com/child.html" scrolling="no" frameborder="0"></iframe>
<input type="button" value="send" onclick="sendRequest()" />
<script>
function sendRequest() {
  document.getElementById('test-iframe').src += '#a';
}
var interval = window.setInterval(function(){
  if(location.hash) {
    alert(location.hash);
    window.clearInterval(interval);
  }
},1000);
</script>

子頁面:
復制代碼 代碼如下:

<h1>RRRRRR</h1>
<script>
var url = 'http://www.xxx.com/father.html';
    oldHash = self.location.hash,
    newHash,
    interval = window.setInterval(function(){
        newHash = self.location.hash;
        if(oldHash != self.location.hash) {
        document.getElementsByTagName('h1')[0].innerHTML = 'pp';
        //alert(parent.location.href); //去掉這個注釋,瀏覽器會提示無權限
        parent.location.href = url + '#b';
          window.clearInterval(interval);
        }
    },500);
</script>

小結:
•1 經測試 IE6, IE7, IE8, Firefox2.0, Firefox3.0, Firefox3.6, Chrome8, Opera11, Safari5, 除 IE6, IE7 外只要改變hash 就會記錄在瀏覽器 history 中。
•2 我有試圖在子頁面用 parent.location.replace 的方法來避免父頁面向服務器發送請求而進行跳轉,這樣理論上瀏覽器就不會記錄歷史,但未能奏效。
•2 子頁面無權讀取父頁面的 url, 但可以對父頁面的 url 進行寫操作,所以跨域操作時,要提前得知父頁面的url
由于前端解決跨域問題的局限性比較大,所以最好用服務器端解決方案
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品国产网站| 成人福利在线观看| 国内精品久久久久| 精品久久久久久国产91| 欧美一级在线亚洲天堂| 亚洲天堂成人在线| 久久在线免费视频| 国产成人欧美在线观看| 欧美日韩国产影院| 国产日韩视频在线观看| 26uuu另类亚洲欧美日本老年| 日韩经典一区二区三区| 久久久免费av| 欧美日韩加勒比精品一区| 亚洲第一精品电影| 欧美成人sm免费视频| 97国产精品视频| 成人亲热视频网站| 国产精品小说在线| 欧美在线亚洲在线| 欧美日韩成人网| 亚洲色图第三页| 中文在线资源观看视频网站免费不卡| 欧美成在线视频| 国产精品久久国产精品99gif| 欧美日韩亚洲国产一区| 正在播放国产一区| 久久香蕉国产线看观看av| 久久在线视频在线| 91免费视频网站| 中文国产成人精品久久一| 亚洲爱爱爱爱爱| 久久久久中文字幕2018| 亚洲性xxxx| 亚洲精品第一国产综合精品| 91在线观看免费高清完整版在线观看| 国产91精品最新在线播放| 久久精品99国产精品酒店日本| 日本一欧美一欧美一亚洲视频| 4k岛国日韩精品**专区| 日韩高清av一区二区三区| 国产成人精品在线| 亚洲午夜女主播在线直播| 4k岛国日韩精品**专区| 美女福利精品视频| 欧美最猛性xxxx| 欧美激情在线狂野欧美精品| 91久久久久久国产精品| 国产精品1区2区在线观看| 亚洲夜晚福利在线观看| 亚洲精品短视频| 欧美日韩激情视频| 亚洲美女久久久| xxx欧美精品| 日韩中文字幕视频在线观看| 日韩中文字幕在线看| 国产欧美一区二区三区四区| 亚洲欧美激情一区| 97久久精品人人澡人人爽缅北| 亚洲精品久久久久久久久| 日韩视频在线免费| 亚洲品质视频自拍网| 97视频免费在线观看| 欧美整片在线观看| 中文字幕日韩av综合精品| 一本大道久久加勒比香蕉| 亚洲国产欧美一区| 亚洲精品短视频| 黄网动漫久久久| 成人欧美一区二区三区在线| 激情懂色av一区av二区av| www.亚洲天堂| 亚洲欧美日韩成人| 免费不卡在线观看av| 欧美日韩另类在线| 精品高清一区二区三区| 亚洲欧洲第一视频| 国产美女91呻吟求| 久久这里有精品视频| 在线播放国产精品| 日韩最新在线视频| x99av成人免费| 91久久在线观看| 精品欧美一区二区三区| 精品久久久久人成| 国产97在线播放| 欧美高清自拍一区| 久久全球大尺度高清视频| 日韩精品视频免费专区在线播放| 国产精品视频内| 在线日韩欧美视频| 91tv亚洲精品香蕉国产一区7ujn| 亚洲欧美自拍一区| 国产成人+综合亚洲+天堂| 中文字幕亚洲二区| 久久九九免费视频| 欧美大片va欧美在线播放| 日韩在线国产精品| 激情成人在线视频| 国产69精品99久久久久久宅男| 91av在线看| 欧美日韩国产区| 亚洲一区制服诱惑| 色狠狠久久aa北条麻妃| 国产精品福利在线| 欧美黑人极品猛少妇色xxxxx| 国产精品久久一区| 国产成人久久精品| 欧美孕妇孕交黑巨大网站| 久久久久久久国产精品| 亚洲男人的天堂网站| 成人国产亚洲精品a区天堂华泰| 欧美中文字幕在线| 高潮白浆女日韩av免费看| 成人夜晚看av| 日韩av最新在线观看| 久久精品免费播放| 成人黄色短视频在线观看| 精品日韩视频在线观看| 日本精品免费观看| 国产欧美久久久久久| 亚洲国产成人精品久久久国产成人一区| 亚洲a一级视频| 久久夜色精品国产| 中文字幕久久精品| 55夜色66夜色国产精品视频| 日韩国产欧美精品一区二区三区| 日韩精品中文字幕视频在线| 亚洲女人被黑人巨大进入al| 国产不卡一区二区在线播放| 国产极品jizzhd欧美| 日韩在线视频网| 亚洲成色777777女色窝| 国产一区二区三区在线播放免费观看| 国产精品一区二区av影院萌芽| 日韩美女av在线| 91精品国产91久久久久久不卡| 国产精品久久久av| 久久视频在线播放| 亚洲免费av电影| 亚洲欧洲偷拍精品| 中文字幕免费精品一区高清| 国产精品久久久久久av福利| 国产婷婷色综合av蜜臀av| 亚洲精品福利资源站| 538国产精品一区二区免费视频| 亚洲精品国产免费| 久久久免费观看视频| 啪一啪鲁一鲁2019在线视频| 国产精品视频xxx| 欧美性69xxxx肥| 色综合亚洲精品激情狠狠| 亚洲自拍av在线| 国产精品久久久久7777婷婷| 日韩高清av一区二区三区| 91精品免费看| 亚洲黄色av女优在线观看| 久久久精品2019中文字幕神马| 亚洲 日韩 国产第一| 国产视频久久久久久久| 久久国产视频网站| 综合国产在线观看| 亚洲伊人久久综合| 91精品久久久久久久久久入口|