JS跨域取XML--借助AS的URLLoader
發(fā)布時(shí)間:2013-04-08 12:16:41 作者:佚名
我要評(píng)論

本篇文章小編將為大家介紹JS跨域取XML--借助AS的URLLoader,有需要的朋友可以參考一下
最近接到一個(gè)功能拓展需求,新需求中所引用的數(shù)據(jù)接口卻只能提供XML格式……無奈自身功力有限,沒有想到JS方面理想的解決方案,只好尋求AS工程師的幫忙,經(jīng)過近2天的聯(lián)調(diào),最終解決了各瀏覽下的跨域訪問。
下面記錄demo版代碼:
父頁面HTML:
<iframe id="hiddenIframe" style="width:0px; height:0px0; border:0px none; *width:1px; *height:0px; overflow:hidden;"></iframe>
<button value="獲取數(shù)據(jù)" onclick="getData()"></button>
<!-- 為什么沒有直接display:none;或者visibility: hidden;? 【稍后解釋:標(biāo)記】-->
父頁面JS:
document.domain = "xxx.com";
function getData(data) {
if (data == "" || data == undefined || data == null) {
sendData("a=1&b=2"); //參數(shù)格式任意,相當(dāng)于你get請求時(shí)發(fā)的參數(shù)
}
else {
alert("獲取的數(shù)據(jù):" + data)
} }
function sendData(param) {
var childWindow = document.getElementById('testIframe').contentWindow;
childWindow.sendData(param); //驅(qū)動(dòng)作用,驅(qū)動(dòng)隱藏域內(nèi)的方法去調(diào)用AS中獲取XML的API方法
}
function change() {
document.getElementById("testIframe").src = "xx.html"; //隱藏域URL
}
子頁面JS:
document.domain = "xxx.com";
function sendData(paramFromParent) {
var severUrl = 'xxx.com';
//此處對(duì)paramFromParent進(jìn)行處理 獲得完整的方位xxx.xml的URL
//然后調(diào)用AS的URLLoader方法去獲取URL下的數(shù)據(jù)
//獲取成功后調(diào)用下面的方法驅(qū)動(dòng)父頁面中的getData方法
}
function getData(backData) {
window.parent.getData(backData);
}
標(biāo)記:沒有用display或者visibility是因?yàn)椋涸贗E瀏覽器下,當(dāng)你的iframe元素設(shè)置樣式為此兩點(diǎn)時(shí)候,框架內(nèi)的JS不進(jìn)行加載,也就無法進(jìn)行通信了......
方便理解,上圖說話

程序流程:
1.加載JS,聲明父頁面window下的sendData和getData方法
2.加載iframe
3.iframe中運(yùn)行其中的AS代碼
4.AS跨域獲取xml文件解析處理
5.調(diào)用window.parent.getData以驅(qū)動(dòng)父頁面JS,傳遞數(shù)據(jù)解析處理好的數(shù)據(jù)
下面記錄demo版代碼:
父頁面HTML:
復(fù)制代碼
代碼如下:<iframe id="hiddenIframe" style="width:0px; height:0px0; border:0px none; *width:1px; *height:0px; overflow:hidden;"></iframe>
<button value="獲取數(shù)據(jù)" onclick="getData()"></button>
<!-- 為什么沒有直接display:none;或者visibility: hidden;? 【稍后解釋:標(biāo)記】-->
父頁面JS:
復(fù)制代碼
代碼如下:document.domain = "xxx.com";
function getData(data) {
if (data == "" || data == undefined || data == null) {
sendData("a=1&b=2"); //參數(shù)格式任意,相當(dāng)于你get請求時(shí)發(fā)的參數(shù)
}
else {
alert("獲取的數(shù)據(jù):" + data)
} }
function sendData(param) {
var childWindow = document.getElementById('testIframe').contentWindow;
childWindow.sendData(param); //驅(qū)動(dòng)作用,驅(qū)動(dòng)隱藏域內(nèi)的方法去調(diào)用AS中獲取XML的API方法
}
function change() {
document.getElementById("testIframe").src = "xx.html"; //隱藏域URL
}
子頁面JS:
復(fù)制代碼
代碼如下:document.domain = "xxx.com";
function sendData(paramFromParent) {
var severUrl = 'xxx.com';
//此處對(duì)paramFromParent進(jìn)行處理 獲得完整的方位xxx.xml的URL
//然后調(diào)用AS的URLLoader方法去獲取URL下的數(shù)據(jù)
//獲取成功后調(diào)用下面的方法驅(qū)動(dòng)父頁面中的getData方法
}
function getData(backData) {
window.parent.getData(backData);
}
標(biāo)記:沒有用display或者visibility是因?yàn)椋涸贗E瀏覽器下,當(dāng)你的iframe元素設(shè)置樣式為此兩點(diǎn)時(shí)候,框架內(nèi)的JS不進(jìn)行加載,也就無法進(jìn)行通信了......
方便理解,上圖說話

程序流程:
1.加載JS,聲明父頁面window下的sendData和getData方法
2.加載iframe
3.iframe中運(yùn)行其中的AS代碼
4.AS跨域獲取xml文件解析處理
5.調(diào)用window.parent.getData以驅(qū)動(dòng)父頁面JS,傳遞數(shù)據(jù)解析處理好的數(shù)據(jù)
相關(guān)文章
15 個(gè)為編程初學(xué)者準(zhǔn)備的網(wǎng)站(都是國外的一些網(wǎng)站)
今天的文章,我們將分享15個(gè)可以學(xué)習(xí)編程的網(wǎng)站,這些網(wǎng)站上提供了很多編程教程,圖書以及編程練習(xí),希望對(duì)你有用2024-11-02- 這篇文章主要介紹了web開發(fā)中的長度單位主要包括px,pt,em等,需要的朋友可以參考下2023-08-06
網(wǎng)頁前端開發(fā)的一些尺寸單位(px,rem單位)
px單位是絕對(duì)單位,一般用于pc端網(wǎng)頁開發(fā),因?yàn)槭墙^對(duì)單位所以在移動(dòng)端上的使用體驗(yàn)并不是很好,rem它是描述相對(duì)于當(dāng)前根元素字體尺寸,是相對(duì)單位,它可以根據(jù)根元素的變換而2023-08-06WEB前端優(yōu)化必備js/css壓縮工具YUI-compressor詳解與集成用法
壓縮工具層次不窮,各有優(yōu)點(diǎn),選擇適合的壓縮工具為將來做項(xiàng)目開發(fā)使用是一件很重要的事情!!在這介紹YUI-compressor,需要的朋友可以參考下2023-06-21- 瀏覽器是多進(jìn)程的,有瀏覽器主進(jìn)程,網(wǎng)絡(luò)進(jìn)程,渲染進(jìn)程,插件進(jìn)程等,在將html,css,javascript解析成一個(gè)頁面的時(shí)候,就需要多個(gè)進(jìn)程的分工合作2023-05-01
- 本文為大家整理了常用的文件對(duì)應(yīng)的MIME類型,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-25
postman中form-data、x-www-form-urlencoded、raw、binary的區(qū)別介紹
這篇文章介紹了postman中form-data、x-www-form-urlencoded、raw、binary的區(qū)別,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-12-28網(wǎng)頁中使用Unicode字符的介紹(&#,\u等)
國際組織制定了可以容納世界上所有文字和符號(hào)的字符編碼方案,稱為Unicode,是通用字符集Universal Character Set的縮寫,用以滿足跨語言、跨平臺(tái)進(jìn)行文本轉(zhuǎn)換、處理的要求2021-11-27前端實(shí)現(xiàn)字符串GBK與GB2312的編解碼(小結(jié))
這篇文章主要介紹了前端實(shí)現(xiàn)字符串GBK與GB2312的編解碼(小結(jié)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2020-12-02告別硬編碼讓你的前端表格自動(dòng)計(jì)算的實(shí)例代碼
這篇文章主要介紹了告別硬編碼讓你的前端表格自動(dòng)計(jì)算,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-27