jQuery使用JSONP實(shí)現(xiàn)跨域獲取數(shù)據(jù)的三種方法詳解
本文實(shí)例講述了jQuery使用JSONP實(shí)現(xiàn)跨域獲取數(shù)據(jù)的三種方法。分享給大家供大家參考,具體如下:
第一種方法是在ajax函數(shù)中設(shè)置dataType為'jsonp'
$.ajax({ dataType: 'jsonp', url: 'http://www.a.com/user?id=123', success: function(data){ //處理data數(shù)據(jù) } });
第二種方法是利用getJSON來實(shí)現(xiàn),只要在地址中加上callback=?參數(shù)即可
$.getJSON('http://www.a.com/user?id=123&callback=?', function(data){ //處理data數(shù)據(jù) });
第三種方法是使用getScript方法
//此時(shí)也可以在函數(shù)外定義foo方法 function foo(data){ //處理data數(shù)據(jù) } $.getScript('http://www.a.com/user?id=123&callback=foo');
實(shí)例演練:
index.html
<!doctype html> <html> <head> <meta charset="utf-8"> <title>jsonp</title> <script src="jquery-1.8.0.min.js"></script> <script> $.ajax({ type : "post", url : "jsonp.php?name=zhaoxiace&age=30", dataType : "jsonp", jsonp: "callbackParam",//傳遞給請求處理程序或頁面的,用以獲得jsonp回調(diào)函數(shù)名的參數(shù)名(默認(rèn)為:callback) jsonpCallback:"callbackFunction",//自定義的jsonp回調(diào)函數(shù)名稱,默認(rèn)為jQuery自動(dòng)生成的隨機(jī)函數(shù)名 success : function(data){ console.log(data.statusCode + "/" + data.message + "/" + data.name + "/" + data.age); }, error:function(){ alert('請求失敗'); } }); </script> </head>
jsonp.php
<? $data["age"] = $_GET['age']; $data["name"] = $_GET['name']; $data["statusCode"]="200"; $data["message"]="成功"; $tmp= json_encode($data); //json數(shù)據(jù) echo $callback . '(' . $tmp .')'; //返回格式,必需 ?>
PS:關(guān)于json操作,這里再為大家推薦幾款比較實(shí)用的json在線工具供大家參考使用:
在線JSON代碼檢驗(yàn)、檢驗(yàn)、美化、格式化工具:
http://tools.jb51.net/code/json
JSON在線格式化工具:
http://tools.jb51.net/code/jsonformat
在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson
json代碼在線格式化/美化/壓縮/編輯/轉(zhuǎn)換工具:
http://tools.jb51.net/code/jsoncodeformat
在線json壓縮/轉(zhuǎn)義工具:
http://tools.jb51.net/code/json_yasuo_trans
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery操作json數(shù)據(jù)技巧匯總》、《jQuery form操作技巧匯總》、《jQuery常用插件及用法總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery表格(table)操作技巧匯總》及《jquery選擇器用法總結(jié)》
希望本文所述對大家jQuery程序設(shè)計(jì)有所幫助。
- 輕松搞定jQuery+JSONP跨域請求的解決方案
- 使用jquery的jsonp如何發(fā)起跨域請求及其原理詳解
- 原生js jquery ajax請求以及jsonp的調(diào)用方法
- 關(guān)于jQuery.ajax()的jsonp碰上post詳解
- jQuery中JSONP的兩種實(shí)現(xiàn)方式詳解
- 淺談JQuery+ajax+jsonp 跨域訪問
- 解決jQuery使用JSONP時(shí)產(chǎn)生的錯(cuò)誤
- 用jQuery與JSONP輕松解決跨域訪問的問題
- jquery ajax jsonp跨域調(diào)用實(shí)例代碼
- jQuery使用jsonp實(shí)現(xiàn)百度搜索的示例代碼
相關(guān)文章
JQuery事件委托(適用于給動(dòng)態(tài)生成的腳本元素添加事件)
jq寫了點(diǎn)擊事件,是通過獲取元素的類名被點(diǎn)擊后執(zhí)行對應(yīng)方法,但是研發(fā)套完模板,他會(huì)把所有的結(jié)構(gòu)先清空,導(dǎo)致jq根本找不到那個(gè)元素,所以事件就不得執(zhí)行了,需要的朋友可以參考下2020-02-02深入理解jQuery中l(wèi)ive與bind方法的區(qū)別
本篇文章主要是對jQuery中l(wèi)ive與bind方法的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12jQuery+canvas實(shí)現(xiàn)的球體平拋及顏色動(dòng)態(tài)變換效果
這篇文章主要介紹了jQuery+canvas實(shí)現(xiàn)的球體平拋及顏色動(dòng)態(tài)變換效果,通過jQuery結(jié)合html5的canvas技術(shù)調(diào)用時(shí)間函數(shù)實(shí)時(shí)進(jìn)行數(shù)學(xué)運(yùn)算,最終實(shí)現(xiàn)球體平拋及顏色動(dòng)態(tài)變換的效果,需要的朋友可以參考下2016-01-01