jQuery中JSONP的兩種實(shí)現(xiàn)方式詳解
前臺(tái)代碼如下:
后臺(tái)Action代碼如下:
運(yùn)行后就可以看到結(jié)果了。我追蹤了下后臺(tái)ProcessCallback代碼,如下圖:
可以看到j(luò)sonCallback的值為"jQuery17104721....",它是前端傳給遠(yuǎn)程服務(wù)器后臺(tái)Action的。這里 jQuery171..表示的是jQuery的版本,可以簡(jiǎn)單地將這個(gè)理解為JSONP類型請(qǐng)求回調(diào)函數(shù),jQuery在我們每次指定Ajax請(qǐng)求方式為 JSONP時(shí)都會(huì)生成這么一個(gè)JSONP回調(diào)函數(shù)。雖然jQuery會(huì)自動(dòng)幫我們生成一個(gè)回調(diào)函數(shù),但是我們也可以通過(guò)設(shè)置 jsonpCallback 參數(shù)為jsonp請(qǐng)求定制一個(gè)我們自己的回調(diào)函數(shù)。
第一種方式下面這三行代碼設(shè)定了JSONP請(qǐng)求方式:
dataType: "jsonp",
jsonp: "jsonpcallback",// 指定回調(diào)函數(shù),這里名字可以為其他任意你喜歡的,比如callback,不過(guò)必須與下一行的GET參數(shù)一致
data: "name=jxq&email=feichexia@yahoo.com.cn&jsonpcallback=?", // jsonpcallback與上面的jsonp值一致
第二種方式則直接在GET參數(shù)后面帶上jsonpcallback=?來(lái)標(biāo)識(shí)。
我們可以推斷這么做以后,jQuery內(nèi)部機(jī)制就幫我們繞過(guò)了瀏覽器的跨域訪問(wèn)限制,然后就可以像正常請(qǐng)求同域Action一樣請(qǐng)求跨域Action了。
最后返回的是一個(gè)函數(shù)表達(dá)式:
return jsonCallback + "(" + new JavaScriptSerializer().Serialize(user) + ")";
這樣返回給前端的就是類似這種jQuery17104721....('{Name:"jxq", Email:"feichexia@yahoo.com.cn"}'),它一返回到前端就會(huì)執(zhí)行,得到的是一個(gè)JavaScript對(duì)象,對(duì)象有兩個(gè)屬 性:Name和Email,所以我們可以直接調(diào)用json.Name和json.Email
通過(guò)此文,希望能幫助大家學(xué)習(xí)掌握此部分知識(shí),謝謝大家對(duì)本站的支持!
- 輕松搞定jQuery+JSONP跨域請(qǐng)求的解決方案
- 使用jquery的jsonp如何發(fā)起跨域請(qǐng)求及其原理詳解
- 原生js jquery ajax請(qǐng)求以及jsonp的調(diào)用方法
- 關(guān)于jQuery.ajax()的jsonp碰上post詳解
- jQuery使用JSONP實(shí)現(xiàn)跨域獲取數(shù)據(jù)的三種方法詳解
- 淺談JQuery+ajax+jsonp 跨域訪問(wèn)
- 解決jQuery使用JSONP時(shí)產(chǎn)生的錯(cuò)誤
- 用jQuery與JSONP輕松解決跨域訪問(wèn)的問(wèn)題
- jquery ajax jsonp跨域調(diào)用實(shí)例代碼
- jQuery使用jsonp實(shí)現(xiàn)百度搜索的示例代碼
相關(guān)文章
如何解決Jquery庫(kù)及其他庫(kù)之間的$命名沖突
這篇文章介紹了Jquery庫(kù)及其他庫(kù)之間的$命名沖突的解決方法,有需要的朋友可以參考一下2013-09-09jQuery EasyUI NumberBox(數(shù)字框)的用法
jQuery EasyUI 數(shù)字框(NumberBox)用法2010-07-07jquery實(shí)現(xiàn)checkbox 全選/全不選的通用寫法
本篇文章主要是對(duì)jquery實(shí)現(xiàn)checkbox 全選/全不選的通用寫法進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02基于jquery可配置循環(huán)左右滾動(dòng)例子
基于jquery可配置循環(huán)左右滾動(dòng)例子,喜歡的朋友可以參考下。2011-09-09