亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢(xún)客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

今天我們聊一下前端中非常基礎(chǔ)的一個(gè)知識(shí)點(diǎn)——iframe跨域。

作為一名前端,在業(yè)務(wù)中你可能會(huì)遇到這樣一個(gè)場(chǎng)景:自己開(kāi)發(fā)的頁(yè)面中需要通過(guò)iframe嵌入別人的頁(yè)面,比如passport頁(yè)面(登錄),但是常常因?yàn)榭缬騿?wèn)題,導(dǎo)致父子頁(yè)面無(wú)法通信,這時(shí)我們就要想辦法如何在跨域的情況下解決這個(gè)問(wèn)題。

什么是跨域?協(xié)議、域名、端口三者中只要有一個(gè)不一樣就是跨域!

假設(shè)我們有以下場(chǎng)景:

父頁(yè)面a通過(guò)iframe內(nèi)嵌子頁(yè)面b,兩頁(yè)面之間想互相獲取dom等信息,該怎么辦?

a頁(yè)面地址:http://jerry.demo.com:8999/a.html
b頁(yè)面地址:http://channel.demo.com:9999/b.html

這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖1


這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖2


這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖3

如果父子頁(yè)面直接操作對(duì)方,就會(huì)產(chǎn)生圖3中的跨域報(bào)錯(cuò)!

document.domain

如果只是主域名不同,其他都相同,就可以采用這種方式。比如以上場(chǎng)景的情況,可以設(shè)置

document.domain = 'demo.com';

location.hash

利用頁(yè)面url的hash值解決。

a父頁(yè)面可以將信息放到子頁(yè)面url的hash值中,然后在子頁(yè)面的內(nèi)部監(jiān)聽(tīng)hash值的變化。

這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖4

這種實(shí)現(xiàn)方式可以讓子頁(yè)面拿到父頁(yè)面的信息,但是如何讓父頁(yè)面拿到子頁(yè)面的信息呢?

b頁(yè)面改變a頁(yè)面地址hash值,a頁(yè)面監(jiān)聽(tīng)地址欄的變化獲取相應(yīng)的數(shù)據(jù),但是a、b頁(yè)面不同源,b頁(yè)面不能直接操作改變a頁(yè)面地址的hash值。

于是b可以通過(guò)創(chuàng)建c頁(yè)面(圖6所示),讓c和a同源,把值傳給c,c來(lái)改變a的地址hash(圖7所示),從而達(dá)到a、b的通信。

這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖5


這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖6


這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖7

window.name

window.name是個(gè)特殊的值,無(wú)論是iframe內(nèi)嵌的頁(yè)面還是普通的頁(yè)面都存在這個(gè)變量。它有一個(gè)神器的特點(diǎn)就是只要設(shè)置了這個(gè)值之后無(wú)論如何修改頁(yè)面的地址(哪怕是跨域的地址),這個(gè)值都會(huì)一直存在。(跟著頁(yè)面窗口存在而不是跟著地址存在)

父到子通信:

這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖8

在a頁(yè)面中先插入c,a和c同源,所以可以先在a頁(yè)面中操作c頁(yè)面的window.name,然后再把iframe的src指向b頁(yè)面,b和c處于一個(gè)iframe窗口,這時(shí)window.name的值就可以在b頁(yè)面中獲取到!

子到父通信:

這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖9

過(guò)程正好反過(guò)來(lái),先插入b,b頁(yè)面中修改window.name,然后再把iframe頁(yè)面替換成c,因?yàn)閍和c同源,所以a頁(yè)面就能拿到window.name的值。

此處比較尷尬的是需要隱藏iframe。

window.postMessage

HTML5引入了跨文檔通信 API,使用targetWidw.postMessage發(fā)送消息,window.onmessage監(jiān)聽(tīng)接收消息。

這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖10


這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖11

使用時(shí),這個(gè)API的兼容性需要考慮一下。

這些iframe跨域解決方案你需要了解一下,以后不應(yīng)該再是你的盲區(qū)

圖12

總結(jié)

iframe跨域的場(chǎng)景還是非常多的,在整個(gè)前端的職業(yè)生涯中肯定會(huì)遇到!如果不了解以上解決問(wèn)題的手段,遇到這類(lèi)問(wèn)題就會(huì)很惱人,希望看完這篇文章的讀者都能完全掌握。

分享到:
標(biāo)簽:iframe
用戶(hù)無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定