亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

輕松搞定jQuery+JSONP跨域請求的解決方案

 更新時(shí)間:2018年03月06日 08:52:28   作者:螞蹄兒  
了解了jsonp之后,大家應(yīng)該也都明白了,jsonp主要就是用來實(shí)現(xiàn)跨域的獲取數(shù)據(jù),今天我們就來詳細(xì)探討下如何在實(shí)際中應(yīng)用jsonp實(shí)現(xiàn)跨域

  JSONP(JSON with Padding)是JSON的一種“使用模式”,可用于解決主流瀏覽器的跨域數(shù)據(jù)訪問的問題。由于同源策略,一般來說位于 server1.example.com 的網(wǎng)頁無法與不是 server1.example.com的服務(wù)器溝通,而 HTML 的<script> 元素是一個(gè)例外。利用 <script> 元素的這個(gè)開放策略,網(wǎng)頁可以得到從其他來源動(dòng)態(tài)產(chǎn)生的 JSON 資料,而這種使用模式就是所謂的 JSONP。用 JSONP 抓到的資料并不是 JSON,而是任意的JavaScript,用 JavaScript 直譯器執(zhí)行而不是用 JSON 解析器解析。

  上面一段話來自百度百科,概念永遠(yuǎn)是那么抽象難懂,看例子才是最直觀的表現(xiàn)。例子看的多了,領(lǐng)悟到那個(gè)點(diǎn)了,自然自己也會學(xué)著抽象的描述了。這就是為什么常說“學(xué)習(xí)知識是從薄到厚,又由厚到薄的過程”。好了扯遠(yuǎn)了。下面直接來看一個(gè)例子。

 

  問題:本地現(xiàn)有一個(gè)頁面demo.html需要從http://localhost:3561/User/GetAllNames獲取數(shù)據(jù)并展示。

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

  ① 客戶端編寫

  客戶端使用jQuery中提供的$.getJson方法來跨域訪問。getJson有3個(gè)參數(shù):

    I.   url:請求地址;

    II.  data:發(fā)送到服務(wù)端的參數(shù);

    III. callback:成功時(shí)的回調(diào)函數(shù)。

  getJson的使用方法和普通的$.get方法基本一致,不同的地方在于getJson需要在url后面的參數(shù)部分加上callback=?這一固定部分,jQuery 將自動(dòng)替換 ? 為正確的函數(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自動(dòng)生成并傳到服務(wù)端的函數(shù)名稱。下面使用C#實(shí)現(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>");
    }
  }
});

相關(guān)文章

  • jQuery 三擊事件實(shí)現(xiàn)代碼

    jQuery 三擊事件實(shí)現(xiàn)代碼

    jQuery 中自帶有雙擊事件,那么當(dāng)需要三擊某對象執(zhí)行某個(gè)事件時(shí)怎么辦呢?今天就讓我們看看一段 jQuery 三擊事件代碼
    2013-09-09
  • jQuery輪播圖實(shí)例詳解

    jQuery輪播圖實(shí)例詳解

    這篇文章主要為大家詳細(xì)介紹了jQuery輪播圖的實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • AJAX在JQuery中的應(yīng)用詳解

    AJAX在JQuery中的應(yīng)用詳解

    今天小編就為大家分享一篇關(guān)于AJAX在JQuery中的應(yīng)用詳解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • jQuery源碼分析之sizzle選擇器詳解

    jQuery源碼分析之sizzle選擇器詳解

    jquery從1.3開始,使用了新的選擇器–sizzle。效率超過了以前的jquery版本的其他選擇器。下面這篇文章主要介紹了jQuery源中sizzle選擇器的相關(guān)資料,文中介紹的很詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • jQuery 滑動(dòng)方法slideDown向下滑動(dòng)元素

    jQuery 滑動(dòng)方法slideDown向下滑動(dòng)元素

    通過 jQuery,您可以在元素上創(chuàng)建滑動(dòng)效果,jQuery slideDown() 方法用于向下滑動(dòng)元素,下為大家介紹下其參數(shù)含義
    2014-01-01
  • Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法總結(jié)

    Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法總結(jié)

    本文是對Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用進(jìn)行了詳細(xì)的總結(jié)介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-11-11
  • 基于jquery.Jcrop的頭像編輯器

    基于jquery.Jcrop的頭像編輯器

    在網(wǎng)上找到了jquery.Jcrop,基本滿足了我的需求,但它只是簡單的切割而已,還有縮略圖沒有生成.或許有很多人都需要這類東西吧,于是我把它封裝起來了,方便其它朋友直接使用.
    2010-03-03
  • 做好七件事幫你提升jQuery的性能

    做好七件事幫你提升jQuery的性能

    這篇文章主要介紹了做好七件事幫你提升jQuery的性能的相關(guān)資料,需要的朋友可以參考下
    2014-02-02
  • jquery validate和jquery form 插件組合實(shí)現(xiàn)驗(yàn)證表單后AJAX提交

    jquery validate和jquery form 插件組合實(shí)現(xiàn)驗(yàn)證表單后AJAX提交

    在ajax流行的時(shí)代,好像很少能看見傳統(tǒng)的同步提交表單方式了,是啊我們當(dāng)然要用更加給力的AJAX來實(shí)現(xiàn)異步無刷新提交表單,好了開始今天的jQuery之旅吧,今天我們來利用jquery.validate和jquery.form 插件組合實(shí)現(xiàn)驗(yàn)證表單后AJAX提交 ,需要的朋友可以參考下
    2015-08-08
  • 如何用jquery控制表格奇偶行及活動(dòng)行顏色

    如何用jquery控制表格奇偶行及活動(dòng)行顏色

    這篇文章主要介紹了如何用jquery控制表格奇偶行及活動(dòng)行顏色,需要的朋友可以參考下
    2014-04-04

最新評論