jquery中的ajax方法怎樣通過JSONP進行遠程調用
更新時間:2014年05月04日 11:19:35 作者:
這篇文章主要介紹了jquery中的ajax方法怎樣通過JSONP進行遠程調用,需要的朋友可以參考下
關于JSONP的概念和為什么要使用JSONP網(wǎng)上已經(jīng)有很多教程,這一節(jié)主要演示下在JQUERY中的ajax方法怎樣通過JSONP進行遠程調用
首先介紹下$.ajax的參數(shù)
type:請求方式 GET/POST
url:請求地址
async:布爾類型,默認為true 表示請求是否為異步,如果為false表示為同步。
dataType:返回的數(shù)據(jù)類型
jsonp:傳遞給請求處理程序或頁面的,用以獲得jsonp回調函數(shù)名的參數(shù)名(一般默認為:callback)
jsonpCallback:自定義的jsonp回調函數(shù)名稱,默認為jQuery自動生成的隨機函數(shù)名,也可以寫"?",jQuery會自動為你處理數(shù)據(jù)
success:調用成功執(zhí)行的函數(shù)
error:異常處理函數(shù)
1.示例1
服務器端我們采用MVC的ACTION來返回數(shù)據(jù)
public class HomeController : Controller
{
//
// GET: /Home/
public ActionResult Index()
{
returnView();
}
public ActionResult ReturnJson()
{
string callback = Request.QueryString["callback"];
string json = "{'name':'張三','age':'20'}";
string result = string.Format("{0}({1})", callback, json);
returnContent(result);
}
}
客戶端使用jsonp來傳輸數(shù)據(jù)
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<script src="~/Scripts/jquery-1.7.1.min.js"type="text/javascript"> </script>
<script type="text/javascript">
functionSendData()
{
$.ajax({
type: "get",
async: false,
url: "/home/ReturnJson",
dataType: "jsonp",
success: function(data){
alert(data.name);
},
error: function(){
alert('fail');
}
});
}
</script>
<input type="button" value="提交" onclick="SendData();"/>
點擊提交按鈕后,發(fā)現(xiàn)服務器端的Request.QueryString["callback"]返回一個隨機函數(shù)名。這樣就被設置成JSONP格式來傳遞數(shù)據(jù)了
2.自定義函數(shù)名
可以在傳遞過程中自定義函數(shù)名,只要使用jsonpCallback參數(shù)就可以了。
jsonp:表示傳遞的參數(shù),默認為callback,我們也可以自定義,服務器段通過此參數(shù),獲取自定義的函數(shù)名稱,服務器這樣獲取 Request.QueryString["callback"]
jsonpCallback表示傳遞的參數(shù)值,也就是回調的函數(shù)名稱,這是自定義的名稱。
<script type="text/javascript">
functionSendData() {
$.ajax({
type: "get",
async: false,
url: "/home/ReturnJson",
dataType: "jsonp",
jsonp: "callback",//傳遞給請求處理程序或頁面的,用以獲得jsonp回調函數(shù)名的參數(shù)名(一般默認為:callback)
jsonpCallback: "receive",//自定義的jsonp回調函數(shù)名稱,默認為jQuery自動生成的隨機函數(shù)名,也可以寫"?",jQuery會自動為你處理數(shù)據(jù)
success: function(data) {
alert(data.name);
},
error: function() {
alert('fail');
}
});
}
functionreceive(data) {
alert(data.age);
}
</script>
首先介紹下$.ajax的參數(shù)
type:請求方式 GET/POST
url:請求地址
async:布爾類型,默認為true 表示請求是否為異步,如果為false表示為同步。
dataType:返回的數(shù)據(jù)類型
jsonp:傳遞給請求處理程序或頁面的,用以獲得jsonp回調函數(shù)名的參數(shù)名(一般默認為:callback)
jsonpCallback:自定義的jsonp回調函數(shù)名稱,默認為jQuery自動生成的隨機函數(shù)名,也可以寫"?",jQuery會自動為你處理數(shù)據(jù)
success:調用成功執(zhí)行的函數(shù)
error:異常處理函數(shù)
1.示例1
服務器端我們采用MVC的ACTION來返回數(shù)據(jù)
復制代碼 代碼如下:
public class HomeController : Controller
{
//
// GET: /Home/
public ActionResult Index()
{
returnView();
}
public ActionResult ReturnJson()
{
string callback = Request.QueryString["callback"];
string json = "{'name':'張三','age':'20'}";
string result = string.Format("{0}({1})", callback, json);
returnContent(result);
}
}
客戶端使用jsonp來傳輸數(shù)據(jù)
復制代碼 代碼如下:
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<script src="~/Scripts/jquery-1.7.1.min.js"type="text/javascript"> </script>
<script type="text/javascript">
functionSendData()
{
$.ajax({
type: "get",
async: false,
url: "/home/ReturnJson",
dataType: "jsonp",
success: function(data){
alert(data.name);
},
error: function(){
alert('fail');
}
});
}
</script>
<input type="button" value="提交" onclick="SendData();"/>
點擊提交按鈕后,發(fā)現(xiàn)服務器端的Request.QueryString["callback"]返回一個隨機函數(shù)名。這樣就被設置成JSONP格式來傳遞數(shù)據(jù)了
2.自定義函數(shù)名
可以在傳遞過程中自定義函數(shù)名,只要使用jsonpCallback參數(shù)就可以了。
jsonp:表示傳遞的參數(shù),默認為callback,我們也可以自定義,服務器段通過此參數(shù),獲取自定義的函數(shù)名稱,服務器這樣獲取 Request.QueryString["callback"]
jsonpCallback表示傳遞的參數(shù)值,也就是回調的函數(shù)名稱,這是自定義的名稱。
復制代碼 代碼如下:
<script type="text/javascript">
functionSendData() {
$.ajax({
type: "get",
async: false,
url: "/home/ReturnJson",
dataType: "jsonp",
jsonp: "callback",//傳遞給請求處理程序或頁面的,用以獲得jsonp回調函數(shù)名的參數(shù)名(一般默認為:callback)
jsonpCallback: "receive",//自定義的jsonp回調函數(shù)名稱,默認為jQuery自動生成的隨機函數(shù)名,也可以寫"?",jQuery會自動為你處理數(shù)據(jù)
success: function(data) {
alert(data.name);
},
error: function() {
alert('fail');
}
});
}
functionreceive(data) {
alert(data.age);
}
</script>
相關文章
使用jQueryMobile實現(xiàn)滑動翻頁效果的方法
這篇文章主要介紹了使用jQueryMobile實現(xiàn)滑動翻頁效果的方法,較為詳細的分析了jQueryMobile實現(xiàn)滑動翻頁效果的原理與實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-02-02jquery.fileEveryWhere.js 一個跨瀏覽器的file顯示插件
大牛ppk都說過,在從多表單控件中,上傳文件控件的樣式是最難以控制的。見文章Styling an input type="file"。本插件也多是參考此文2011-10-10setInterval,setTimeout與jquery混用的問題
當遇到setInterval,setTimeout與jquery混用的問題 時,直接按JavaScript中的語法寫并不起作用,有以下兩種解決方法2013-04-04