您好,登錄后才能下訂單哦!
今天小編給大家分享一下如何用jQuery+JSONP實現(xiàn)跨域請求的相關(guān)知識點,內(nèi)容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
??問題:本地現(xiàn)有一個頁面demo.html需要從http://localhost:3561/User/GetAllNames獲取數(shù)據(jù)并展示。
??解答:由于問題中的兩方不在同一服務(wù)器,故需要使用jsonp來跨域訪問。
??① 客戶端編寫
??客戶端使用jQuery中提供的$.getJson方法來跨域訪問。getJson有3個參數(shù):
????I. url:請求地址;
????II. data:發(fā)送到服務(wù)端的參數(shù);
????III. callback:成功時的回調(diào)函數(shù)。
??getJson的使用方法和普通的$.get方法基本一致,不同的地方在于getJson需要在url后面的參數(shù)部分加上callback=?這一固定部分,jQuery 將自動替換 ? 為正確的函數(shù)名,以執(zhí)行回調(diào)函數(shù)。然后在回調(diào)函數(shù)中操作從異域返回的json對象,回調(diào)函數(shù)callback的參數(shù)即為該json對象。
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> </head> <body> <ul id="nameList"></ul> <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script> <script type="text/javascript"> $.getJSON("http://localhost:3561/User/GetAllNames?callback=?", function(json) { for (var i = 0; i < json.length; i++) { $("#nameList").append("<li>" + json[i] + "</li>"); } }); </script> </body> </html>
② 服務(wù)端編寫
??服務(wù)端的邏輯主要是將數(shù)據(jù)序列化為json字符串,然后封裝成"callback(json)"的形式,callback為jQuery自動生成并傳到服務(wù)端的函數(shù)名稱。下面使用C#實現(xiàn):
public class UserController : Controller { public string GetAllNames(string callback) { string[] names = new string[] { "張三豐", "張無忌", "令狐沖", "楊過", "郭靖" }; JavaScriptSerializer jss = new JavaScriptSerializer(); string json = jss.Serialize(names); return string.Format("{0}({1})", callback, json); } }
至此,便成功解決了問題。
?思考:如果服務(wù)端已經(jīng)寫死了callback(如:return string.Format("moty({0})", json);),那么客戶端該怎么寫呢?
?參考:
$.ajax("http://localhost:3561/User/GetAllNames", { jsonpCallback: "moty", dataType: "jsonp", success: function(json) { for (var i = 0; i < json.length; i++) { $("#nameList").append("<li>" + json[i] + "</li>"); } } });
以上就是“如何用jQuery+JSONP實現(xiàn)跨域請求”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。