JSONP 的原理、理解 與 實例分析
本文實例講述了JSONP 的原理、理解 與 實例。分享給大家供大家參考,具體如下:
1.什么是jsonp
1.1 同源策略
瀏覽器同源策略的限制,XmlHttpRequest只允許請求當(dāng)前源(相同域名、協(xié)議、端口)的資源。
-1)jsonp只支持get請求
-2)不受同源策略限制 ,兼容性好 不需要XMLHttpRequest(ActiveX)支持,通過js回調(diào)函數(shù)返回結(jié)果
-3)不能解決 不同域的兩個頁面之間js調(diào)用的問題
2. jsonp 原理
動態(tài)添加一個script標(biāo)簽,get鏈接上發(fā)送回調(diào)函數(shù)名稱 傳給服務(wù)器 服務(wù)器獲取回調(diào)函數(shù)名稱 返回這個函數(shù)名稱的JS函數(shù)(拼裝函數(shù)) json數(shù)據(jù)作為函數(shù)的實際參數(shù)傳入 返回的數(shù)據(jù)是js函數(shù) 在前端調(diào)用回調(diào)函數(shù)( json數(shù)據(jù)傳入) 執(zhí)行回調(diào)函數(shù)
3.實例
先來說說 服務(wù)端應(yīng)該返回的數(shù)據(jù)形式 如下所示 用的php thinphp框架編寫的 訪問URL 是
http://91hx.xicp.cn:8989/Service/Validata/testJsonP?callback=jsonpCallback callback后面的名字要傳給服務(wù)器的 后端拼裝成一個js回調(diào)函數(shù) 這樣前臺json數(shù)據(jù)就作為回調(diào)函數(shù)的參數(shù)傳入 獲取到數(shù)據(jù)了
public function testJsonP(){
$jsonname =I('get.callback');//獲取URL上的callback名稱 也就是獲取jsonpCallback
$a = [name=>'張三',sex=>'男',msg=>'返回成功!'];// 一個數(shù)組數(shù)據(jù)
$json = json_encode($a);// 轉(zhuǎn)成json數(shù)據(jù)
echo $jsonname.'('.$json.');';//正確的格式應(yīng)該是這樣 jsonpCallback({"name":"\u5f20\u4e09","sex":"\u7537","msg":"\u8fd4\u56de\u6210\u529f\uff01"}); 不要忘記分號; 這樣返回的才是一個js函數(shù) 前臺肯定有這個函數(shù)名字才行
}
tip:關(guān)聯(lián)數(shù)組 上面例子 $a = array( "msg" => "返回成功!")
前臺 訪問URL http://localhost:63343/H5/jsonP.html 動態(tài)添加一個script標(biāo)簽 src里 調(diào)用回調(diào)函數(shù) jsonpCallback() . ?callback=jsonpCallback名字隨便起 后端獲取的就是jsonpCallback這個名字而已
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<body>
<script type="text/javascript">
function jsonpCallback(date){
console.log(date);
alert(date);
alert(date.msg);
}
var script =document.createElement('script');
script.src='http://91hx.xicp.cn:8989/Service/Validata/testJsonP?callback=jsonpCallback';
document.body.insertBefore(script,document.body.firstChild);
</script>
</body>
</html>
我們可以在瀏覽器里 這里我用的谷歌直接查看 數(shù)據(jù)是否訪問正確 切換到Network標(biāo)簽下 可以看到生成的訪問地址 點擊然后
這下面的圖 點擊一下左側(cè)鏈接 切換到Response就可以看到響應(yīng)的數(shù)據(jù)了 跟前端寫的函數(shù)名要一致 里面的json數(shù)據(jù)就是 那個函數(shù)的參數(shù) 傳入 別忘記有分號;

前端我們已經(jīng)console.log 數(shù)據(jù)了 也可以查看 切換到Console標(biāo)簽下

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript中ajax操作技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
Firefox下設(shè)為主頁的JavaScript代碼
在IE下,我們可以輕松使用以下代碼來實現(xiàn)設(shè)置主頁 但在firefox我們需要做的更多2008-09-09
微信小程序模板消息限制實現(xiàn)無限制主動推送的示例代碼
這篇文章主要介紹了微信小程序模板消息限制實現(xiàn)無限制主動推送的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08

