使用JavaScript 實現(xiàn)各種跨域的方法
一、一些概念
①傳統(tǒng)Ajax:交互的數(shù)據(jù)格式——自定義字符串或XML描述;
跨域——通過服務(wù)器端代理解決。
②如今最優(yōu)方案:使用JSON格式來傳輸數(shù)據(jù),使用JSONP來跨域。
③JSON:一種數(shù)據(jù)交換格式?;诩兾谋?、被原生JS支持。
格式:兩種數(shù)據(jù)類型描述符:大括號{ }、方括號[ ]。分隔符逗號、映射符冒號、定義符雙引好。
④JSONP:一種跨域數(shù)據(jù)交互協(xié)議,非官方。
1、Web頁面調(diào)用js文件,可跨域。擴展:但凡有src屬性的標(biāo)簽都具有跨域能力。
2、跨域服務(wù)器 動態(tài)生成數(shù)據(jù) 并存入js文件(通常json后綴),供客戶端 調(diào)用。
3、為了便于客戶端使用數(shù)據(jù),形成一個非正式傳輸協(xié)議,稱為JSONP。該協(xié)議重點是允許用戶傳遞一個callback參數(shù)給服務(wù)器,然后服務(wù)器返回數(shù)據(jù)時 將此callback參數(shù)作為函數(shù)名包裹住JSON數(shù)據(jù),使得客戶端可以隨意定制自己的函數(shù)來自動處理返回數(shù)據(jù)。
二、JSONP實現(xiàn)
實例1——客戶端單方面接收:
①客戶端——在客戶端設(shè)置創(chuàng)建一個函數(shù)對象,名稱可為callFunc,用于接收服務(wù)器的js數(shù)據(jù)和對其進行處理。
js數(shù)據(jù)中的核心是:調(diào)用callFunc函數(shù)的同時附帶著參數(shù),此參數(shù)即data對象的值。
<script type="text/javascript">
var callFunc = function(data){
alert('遠(yuǎn)程js文件傳來的數(shù)據(jù):' + data.result);//data為服務(wù)器端的JSON數(shù)據(jù)對象。
};
</script>
<script type="text/javascript" src="http://其他域的js文件.com/remote.js"></script>
②服務(wù)器端——直接調(diào)用客戶端js中的函數(shù),并傳入數(shù)據(jù)。
callFunc({"result":"value1"});
實例2——客戶端向服務(wù)器傳送 指定函數(shù)名,服務(wù)器端接收該函數(shù)名 并調(diào)用對應(yīng)函數(shù) 將數(shù)據(jù)以參數(shù)形式傳入。
<script type="text/javascript">
// 得到航班信息查詢結(jié)果后的回調(diào)函數(shù)
var flightHandler = function(data){
alert('你查詢的航班結(jié)果是:票價 ' + data.price + ' 元,' + '余票 ' + data.tickets + ' 張。');
};
// 動態(tài)添加鏈接服務(wù)器js文件的script。
// 在url地址中傳遞了一個code參數(shù)匹配JSON數(shù)據(jù)中的某個key,callback參數(shù)則告訴服務(wù)器:本地回調(diào)函數(shù)名為callFuncName。
var url = "http://flightQuery.com/jsonp/flightResult.aspx?code=CA1998&callback=callFuncName";
var script = document.createElement('script');
script.setAttribute('src', url);
// 將script元素在網(wǎng)頁加載時插入head頭部
document.getElementsByTagName('head')[0].appendChild(script);
</script>
總結(jié):實現(xiàn)的代碼并不復(fù)雜,但在實現(xiàn)Ajax跨域、frameset/iframe跨域等卻是效率頗高的。
相關(guān)文章
Mobile Web開發(fā)基礎(chǔ)之四--處理手機設(shè)備的橫豎屏問題
這篇文章主要介紹了Mobile Web開發(fā)基礎(chǔ)之-—處理手機設(shè)備的橫豎屏,window.orientation屬性與onorientationchange事件以及media query方式是開發(fā)過程中需要注意到的兩種解決方式,需要的朋友可以參考下2017-08-08
JavaScript高級程序設(shè)計(第3版)學(xué)習(xí)筆記8 js函數(shù)(中)
接著看函數(shù)——這個具有魔幻色彩的對象。在上篇文章中說函數(shù)內(nèi)部屬性時,還遺留了一個this內(nèi)部屬性沒有解釋,不過在說this之前,我想先說一說執(zhí)行環(huán)境和作用域的概念2012-10-10
javaScript獲取對象中非空的屬性實現(xiàn)方法詳解
這篇文章主要為大家介紹了javaScript獲取對象中非空的屬性實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07
javascript學(xué)習(xí)筆記(一)基礎(chǔ)知識
本文是學(xué)習(xí)筆記系列的第一篇,跟以前一樣,介紹些基礎(chǔ)知識,包括js基本概念、 JScript 的變量、js的數(shù)據(jù)類型、3.JScript 的運算符、js流程控制、js函數(shù)。有需要的朋友可以參考下2014-09-09
簡介JavaScript中用于處理正切的Math.tan()方法
這篇文章主要介紹了簡介JavaScript中用于處理正切的Math.tan()方法,是JS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-06-06

