日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

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

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

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

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

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

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

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

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

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

圖1


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

圖2


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

圖3

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

document.domain

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

document.domain = 'demo.com';

location.hash

利用頁面url的hash值解決。

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

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

圖4

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

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

于是b可以通過創(chuàng)建c頁面(圖6所示),讓c和a同源,把值傳給c,c來改變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è)特殊的值,無論是iframe內(nèi)嵌的頁面還是普通的頁面都存在這個(gè)變量。它有一個(gè)神器的特點(diǎn)就是只要設(shè)置了這個(gè)值之后無論如何修改頁面的地址(哪怕是跨域的地址),這個(gè)值都會(huì)一直存在。(跟著頁面窗口存在而不是跟著地址存在)

父到子通信:

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

圖8

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

子到父通信:

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

圖9

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

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

window.postMessage

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

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

圖10


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

圖11

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

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

圖12

總結(jié)

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

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

網(wǎng)友整理

注冊時(shí)間:

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

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

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

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

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

答題星2018-06-03

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

全階人生考試2018-06-03

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

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

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

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

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

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定