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

首頁 > 編程 > JavaScript > 正文

iframe與主框架跨域相互訪問實現方法

2019-11-19 15:26:28
字體:
來源:轉載
供稿:網友

1.同域相互訪問

假設A.html 與 b.html domain都是localhost (同域)
A.html中iframe 嵌入 B.html,name=myframe
A.html有js function fMain()
B.html有js function fIframe()
需要實現 A.html 調用 B.html 的 fIframe(),B.html 調用 A.html 的 fMain()

A.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <title> main window </title> <script type="text/javascript"> // main js function function fMain(){	alert('main function execute success'); } // exec iframe function function exec_iframe(){	window.myframe.fIframe(); } </script> </head> <body> <p>A.html main</p> <p><input type="button" value="exec iframe function" onclick="exec_iframe()"></p> <iframe src="B.html" name="myframe" width="500" height="100"></iframe> </body></html>

B.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <title> iframe window </title> <script type="text/javascript"> // iframe js function  function fIframe(){	alert('iframe function execute success'); } // exec main function function exec_main(){	parent.fMain(); } </script> </head> <body> <p>B.html iframe</p> <p><input type="button" value="exec main function" onclick="exec_main()"></p> </body></html>

點擊A.html 的 exec iframe function button,執行成功,彈出iframe function execute success。如下圖

點擊B.html 的 exec main function button,執行成功,彈出 main function execute success。如下圖

2.跨域互相訪問

假設 A.html domain是 localhost, B.html domain 是 127.0.0.1 (跨域)
這里使用 localhost 與 127.0.0.1 只是方便測試,localhost 與 127.0.0.1已經不同一個域,因此執行效果是一樣的。
實際使用時換成 www.domaina.com 與 www.domainb.com 即可。
A.html中iframe 嵌入 B.html,name=myframe
A.html有js function fMain()
B.html有js function fIframe()
需要實現 A.html 調用 B.html 的 fIframe(),B.html 調用 A.html 的 fMain() (跨域調用)

如果使用上面同域的方法,瀏覽器判斷A.html 與 B.html 不同域,會有錯誤提示。
Uncaught SecurityError: Blocked a frame with origin "http://localhost" from accessing a frame with origin "http://127.0.0.1". Protocols, domains, and ports must match.

實現原理:

因為瀏覽器為了安全,禁止了不同域訪問。因此只要調用與執行的雙方是同域則可以相互訪問。

首先,A.html 如何調用B.html的 fIframe方法
1.在A.html 創建一個 iframe
2.iframe的頁面放在 B.html 同域下,命名為execB.html
3.execB.html 里有調用B.html fIframe方法的js調用

<script type="text/javascript"> parent.window.myframe.fIframe(); // execute parent myframe fIframe function </script> 

這樣A.html 就能通過 execB.html 調用 B.html 的 fIframe 方法了。

同理,B.html 需要調用A.html fMain方法,需要在B.html 嵌入與A.html 同域的 execA.html
execA.html 里有調用 A.html fMain 方法的js 調用

<script type="text/javascript"> parent.parent.fMain(); // execute main function </script> 

這樣就能實現 A.html 與 B.html 跨域相互調用。

A.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <title> main window </title> <script type="text/javascript"> // main js function function fMain(){	alert('main function execute success'); } // exec iframe function function exec_iframe(){	if(typeof(exec_obj)=='undefined'){		exec_obj = document.createElement('iframe');		exec_obj.name = 'tmp_frame';		exec_obj.src = 'http://127.0.0.1/execB.html';		exec_obj.style.display = 'none';		document.body.appendChild(exec_obj);	}else{		exec_obj.src = 'http://127.0.0.1/execB.html?' + Math.random();	} } </script> </head> <body> <p>A.html main</p> <p><input type="button" value="exec iframe function" onclick="exec_iframe()"></p> <iframe src="http://127.0.0.1/B.html" name="myframe" width="500" height="100"></iframe> </body></html>

B.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <title> iframe window </title> <script type="text/javascript"> // iframe js function  function fIframe(){	alert('iframe function execute success'); } // exec main function function exec_main(){	if(typeof(exec_obj)=='undefined'){		exec_obj = document.createElement('iframe');		exec_obj.name = 'tmp_frame';		exec_obj.src = 'http://localhost/execA.html';		exec_obj.style.display = 'none';		document.body.appendChild(exec_obj);	}else{		exec_obj.src = 'http://localhost/execA.html?' + Math.random();	} } </script> </head> <body> <p>B.html iframe</p> <p><input type="button" value="exec main function" onclick="exec_main()"></p> </body></html>

execA.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <title> exec main function </title> </head> <body> 	<script type="text/javascript">		parent.parent.fMain(); // execute main function	</script> </body></html>

execB.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <title> exec iframe function </title> </head> <body>	<script type="text/javascript">		parent.window.myframe.fIframe(); // execute parent myframe fIframe function	</script> </body></html>

執行如下圖:

源碼下載地址:點擊查看

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲激情视频在线| 欧美午夜精品伦理| 91久久夜色精品国产网站| 国产美女精品视频免费观看| 久久视频这里只有精品| 在线观看视频99| 久久精品国产96久久久香蕉| 亚洲tv在线观看| 午夜精品久久久久久久男人的天堂| 福利二区91精品bt7086| 欧美人在线视频| 亚洲精品999| 久久精品青青大伊人av| 欧美成人网在线| 国内揄拍国内精品| 成人综合网网址| 欧美日韩xxx| 亚洲xxxx做受欧美| 社区色欧美激情 | 亚洲性xxxx| 国内精品小视频| 欧美理论片在线观看| 日韩一区在线视频| 日韩中文字幕在线视频| 91在线观看免费高清| 91高清视频免费观看| 中文字幕无线精品亚洲乱码一区| 亚洲精品美女久久久久| 6080yy精品一区二区三区| 国内免费精品永久在线视频| 国产免费久久av| 欧美高清理论片| 91精品视频免费观看| 成人免费xxxxx在线观看| 超碰91人人草人人干| 亚洲欧美日韩精品| 欧美亚洲国产成人精品| 国产欧美一区二区三区四区| 欧美中文字幕在线视频| 久久精品国产91精品亚洲| 国产精品成人免费视频| 欧美午夜宅男影院在线观看| 精品久久久久久国产| 欧美在线观看一区二区三区| 国产精品极品美女粉嫩高清在线| 欧美在线视频一二三| 久久久97精品| 国产剧情日韩欧美| 中文字幕日韩在线观看| 久久这里只有精品99| 亚洲精品国产精品久久清纯直播| 中文字幕精品网| 日韩成人av在线播放| 久久婷婷国产麻豆91天堂| 中文字幕亚洲一区在线观看| 91精品国产色综合久久不卡98口| 亚洲精品久久久久久久久久久久| 欧美综合一区第一页| 亚洲乱码国产乱码精品精天堂| 亚洲精品福利视频| 久久久久久久久久婷婷| 国产成人亚洲精品| 精品视频偷偷看在线观看| 97在线精品国自产拍中文| 欧美精品成人91久久久久久久| 美女福利视频一区| 久久久噜久噜久久综合| 55夜色66夜色国产精品视频| 久久久久久高潮国产精品视| 精品久久久999| 国产精品爱久久久久久久| 国产剧情日韩欧美| 亚洲国产成人久久综合一区| 国产性色av一区二区| 亚洲国产成人精品久久| 91精品啪在线观看麻豆免费| 国产偷亚洲偷欧美偷精品| 日韩av一区二区在线观看| 欧美大片在线影院| 亚洲午夜精品视频| 久久伊人免费视频| 国产精品毛片a∨一区二区三区|国| 97热在线精品视频在线观看| 精品国产福利在线| 日韩成人黄色av| 亚洲精品欧美极品| 国产精品成人aaaaa网站| 亚洲精品国产品国语在线| 国产91精品久| 不卡毛片在线看| 日韩精品中文在线观看| 在线视频亚洲欧美| 欧美精品久久久久| 欧美最猛性xxxx| 国产精品69久久久久| 成人h猎奇视频网站| 日韩高清中文字幕| 懂色av一区二区三区| 精品视频久久久久久久| 91tv亚洲精品香蕉国产一区7ujn| 亚洲国产精品成人av| 中文字幕免费国产精品| 韩国日本不卡在线| 91av国产在线| 久久国产精品视频| 欧美日韩加勒比精品一区| 欧美成人精品在线视频| 国产v综合ⅴ日韩v欧美大片| 国产综合久久久久| 国产精品久久久久国产a级| 亚洲香蕉成人av网站在线观看| 成人福利免费观看| 2021久久精品国产99国产精品| 国产精品欧美风情| 国产精品日日摸夜夜添夜夜av| 欧美自拍视频在线| 久久久国产精品亚洲一区| 欧美性猛交xxxx乱大交蜜桃| 亚洲免费福利视频| 91国内产香蕉| 亚洲国产精品久久久久秋霞蜜臀| 岛国精品视频在线播放| 国模极品一区二区三区| 国模精品视频一区二区| 日韩风俗一区 二区| 国产精品白丝jk喷水视频一区| 日韩69视频在线观看| 精品久久久免费| 亚洲第一综合天堂另类专| 国产亚洲欧美视频| 日韩免费在线免费观看| 欧美另类极品videosbestfree| 欧美精品做受xxx性少妇| 亚洲一区二区在线| 亚洲资源在线看| 日韩视频一区在线| 亚洲天堂日韩电影| 黄色91在线观看| 欧美极品少妇xxxxⅹ裸体艺术| 国产精品美女主播| 亚洲精品免费一区二区三区| 8090成年在线看片午夜| 欧美情侣性视频| 欧美激情亚洲激情| 国产精品视频一区国模私拍| 亚洲成色777777女色窝| 欧美日韩亚洲国产一区| 国产精品久久久久久久久久| 亚洲天堂免费观看| 永久免费精品影视网站| 欧美日韩中文字幕在线| 国产精品成人aaaaa网站| 亚洲欧美制服第一页| 麻豆国产精品va在线观看不卡| 久久深夜福利免费观看| 国产成人涩涩涩视频在线观看| 国产成人久久久| 国产精品久久久精品| 国产在线a不卡| 亚洲人高潮女人毛茸茸| 91精品久久久久久久久久入口| 国产精品美乳一区二区免费| 亚洲欧美日韩在线高清直播| 亚洲精品国产综合久久|