91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何用jQuery+JSONP實現跨域請求

發布時間:2022-03-31 11:13:06 來源:億速云 閱讀:254 作者:iii 欄目:開發技術

今天小編給大家分享一下如何用jQuery+JSONP實現跨域請求的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

??問題:本地現有一個頁面demo.html需要從http://localhost:3561/User/GetAllNames獲取數據并展示。

??解答:由于問題中的兩方不在同一服務器,故需要使用jsonp來跨域訪問。

??① 客戶端編寫

??客戶端使用jQuery中提供的$.getJson方法來跨域訪問。getJson有3個參數:

????I.   url:請求地址;

????II.  data:發送到服務端的參數;

????III. callback:成功時的回調函數。

??getJson的使用方法和普通的$.get方法基本一致,不同的地方在于getJson需要在url后面的參數部分加上callback=?這一固定部分,jQuery 將自動替換 ? 為正確的函數名,以執行回調函數。然后在回調函數中操作從異域返回的json對象,回調函數callback的參數即為該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>

  ② 服務端編寫

??服務端的邏輯主要是將數據序列化為json字符串,然后封裝成"callback(json)"的形式,callback為jQuery自動生成并傳到服務端的函數名稱。下面使用C#實現:

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);
  }
}

  至此,便成功解決了問題。

如何用jQuery+JSONP實現跨域請求

?思考:如果服務端已經寫死了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實現跨域請求”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

海阳市| 石台县| 康定县| 肃宁县| 耒阳市| 邯郸县| 扶余县| 农安县| 手游| 昭觉县| 延寿县| 册亨县| 定南县| 陕西省| 桐城市| 云阳县| 太白县| 辽中县| 柘荣县| 梁山县| 孝昌县| 永新县| 紫金县| 横峰县| 宿迁市| 辽宁省| 交口县| 南投市| 长寿区| 淮北市| 鄂托克前旗| 乐昌市| 临海市| 曲松县| 东阿县| 保亭| 揭东县| 逊克县| 平安县| 嘉定区| 道孚县|