成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

jQuery+JSONP跨域需要如何實(shí)現(xiàn)-創(chuàng)新互聯(lián)

這篇文章主要介紹了jQuery+JSONP跨域需要如何實(shí)現(xiàn),具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

在橋東等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作定制網(wǎng)站制作,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),成都全網(wǎng)營(yíng)銷推廣,外貿(mào)網(wǎng)站建設(shè),橋東網(wǎng)站建設(shè)費(fèi)用合理。

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

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

jQuery+JSONP跨域需要如何實(shí)現(xiàn)

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

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

??① 客戶端編寫

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

????I.   url:請(qǐng)求地址;

????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對(duì)象,回調(diào)函數(shù)callback的參數(shù)即為該json對(duì)象。

<!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[] { "張三豐", "張無(wú)忌", "令狐沖", "楊過(guò)", "郭靖" };
    JavaScriptSerializer jss = new JavaScriptSerializer();
    string json = jss.Serialize(names);
    return string.Format("{0}({1})", callback, json);
  }
}

至此,便成功解決了問(wèn)題。

jQuery+JSONP跨域需要如何實(shí)現(xiàn)

?思考:如果服務(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>");
    }
  }
});

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享jQuery+JSONP跨域需要如何實(shí)現(xiàn)內(nèi)容對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)建站,關(guān)注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道,遇到問(wèn)題就找創(chuàng)新互聯(lián)建站,詳細(xì)的解決方法等著你來(lái)學(xué)習(xí)!

網(wǎng)站欄目:jQuery+JSONP跨域需要如何實(shí)現(xiàn)-創(chuàng)新互聯(lián)
當(dāng)前鏈接:http://jinyejixie.com/article46/dhcseg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、品牌網(wǎng)站設(shè)計(jì)、自適應(yīng)網(wǎng)站、移動(dòng)網(wǎng)站建設(shè)、微信公眾號(hào)、用戶體驗(yàn)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

營(yíng)銷型網(wǎng)站建設(shè)
卢氏县| 翁牛特旗| 泸水县| 洪泽县| 苏尼特左旗| 雅江县| 富锦市| 黄陵县| 巨野县| 平罗县| 金平| 香河县| 梁山县| 错那县| 壤塘县| 清原| 成都市| 公安县| 蒙阴县| 嘉善县| 惠安县| 洪洞县| 民丰县| 商丘市| 和林格尔县| 永德县| 丰城市| 青田县| 乐业县| 兴安盟| 临桂县| 仁布县| 常熟市| 加查县| 沿河| 常山县| 荔浦县| 桂阳县| 惠来县| 盈江县| 璧山县|