佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > PHP ajax跨子域的解決方案之document.domain+iframe實(shí)例分析

PHP ajax跨子域的解決方案之document.domain+iframe實(shí)例分析

熱門標(biāo)簽:Linux服務(wù)器 電子圍欄 科大訊飛語(yǔ)音識(shí)別系統(tǒng) 阿里云 Mysql連接數(shù)設(shè)置 銀行業(yè)務(wù) 團(tuán)購(gòu)網(wǎng)站 服務(wù)器配置

本文實(shí)例講述了PHP ajax跨子域的解決方案之document.domain+iframe。分享給大家供大家參考,具體如下:

對(duì)于主域相同,子域不同,我們可以設(shè)置相同的document.domain來(lái)欺騙瀏覽器,達(dá)到跨子域的效果。

例如:我們有兩個(gè)域名:www.a.com 和 img.a.com

在www.a.com下有a.html

在img.a.com下有img.json和img.html這兩個(gè)文件。

img.json就是一些我們要獲取的數(shù)據(jù):

[
  {
    "name" : "img1",
    "url" : "http://img.a.com/img1.jpg"
  },
  {
    "name" : "img2",
    "url" : "http://img.a.com/img2.jpg"
  }
]

img.html就是我們iframe要引用的:

!DOCTYPE html>
html>
head>
  meta charset="UTF-8">
  title>Insert title here/title>
/head>
body>
script src="./jquery.js">/script>
script type="text/javascript">
  document.domain = "a.com";

  var p = parent.window.$;
  p("#sub").text("我是子頁(yè)面添加的");
/script>
/body>
/html>

a.html就是要通過(guò)跨子域獲取數(shù)據(jù)的頁(yè)面:

!DOCTYPE html>
html>
head>
  meta charset="UTF-8">
  title>Insert title here/title>
/head>
body>
!-- 通過(guò)跨域獲取數(shù)據(jù),并添加到ul中 -->
ul id="data">/ul>

!-- 子頁(yè)面通過(guò)parent.window來(lái)訪問(wèn)父頁(yè)面 -->
div id="sub">/div>

!-- 通過(guò)iframe引用img.a.com下的img.html -->
iframe id="iframe" src="http://img.a.com/img.html">/iframe>

script src="./jquery.js">/script>
script type="text/javascript">
document.domain = "a.com";

$("#iframe").bind("load", function() {
  //獲取子頁(yè)面的jquery對(duì)象
  iframe = document.getElementById("iframe").contentWindow.$;

  iframe.getJSON("http://img.a.com/img.json", function(data) {
    var con = "";
    //注意這里的$對(duì)象是www.a.com上的
    $.each(data, function(i, v) {
      con += "li>" + v.name + ":" + v.url + "/li>";
    });
    $("#data").html(con);
  });
});
/script>
/body>
/html>

a.html中我們通過(guò)contentWindow.$來(lái)獲取子頁(yè)面的jquery對(duì)象,然后通過(guò)getJSON獲取數(shù)據(jù),并通過(guò)www.a.com上的$對(duì)象把數(shù)據(jù)寫入到ul中。

在子頁(yè)面img.html中我們通過(guò)parent.window來(lái)訪問(wèn)父頁(yè)面的$對(duì)象,并操作元素添加數(shù)據(jù)。

更多關(guān)于PHP相關(guān)內(nèi)容可查看本站專題:《PHP+ajax技巧與應(yīng)用小結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP下ajax跨域的解決方案之window.name實(shí)例分析
  • PHP下ajax跨域的解決方案之jsonp實(shí)例分析
  • PHP處理Ajax請(qǐng)求與Ajax跨域問(wèn)題
  • jquery ajax結(jié)合thinkphp的getjson實(shí)現(xiàn)跨域的方法
  • PHP中運(yùn)用jQuery的Ajax跨域調(diào)用實(shí)現(xiàn)代碼
  • php+mysql+ajax 局部刷新點(diǎn)贊/取消點(diǎn)贊功能(每個(gè)賬號(hào)只點(diǎn)贊一次)
  • Jquery+AJAX實(shí)現(xiàn)無(wú)刷新上傳并重命名文件操作示例【PHP后臺(tái)接收】
  • PHP使用ajax的post方式下載excel文件簡(jiǎn)單示例
  • PHP Ajax跨域問(wèn)題解決方案代碼實(shí)例

標(biāo)簽:廣元 衡水 衢州 萍鄉(xiāng) 蚌埠 棗莊 大理 江蘇

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP ajax跨子域的解決方案之document.domain+iframe實(shí)例分析》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    丰城市| 玉树县| 宁南县| 碌曲县| 宁安市| 吉安县| 青浦区| 泗洪县| 大城县| 翁源县| 建德市| 延川县| 鄂尔多斯市| 罗城| 将乐县| 德保县| 汉沽区| 五河县| 枣阳市| 永川市| 调兵山市| 济源市| 白水县| 日土县| 新闻| 辽阳县| 辽阳市| 正蓝旗| 荔波县| 南江县| 德兴市| 东海县| 江油市| 杨浦区| 柳江县| 阿拉善左旗| 河北区| 井冈山市| 巩留县| 宣化县| 昌图县|