<del id="d4fwx"><form id="d4fwx"></form></del>
      <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

            <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
          • jQuery+JSONP跨域需要如何實現(xiàn)-創(chuàng)新互聯(lián)

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

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

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

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

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

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

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

            ??① 客戶端編寫

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

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

            ????II.  data:發(fā)送到服務端的參數(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>

            ② 服務端編寫

            ??服務端的邏輯主要是將數(shù)據(jù)序列化為json字符串,然后封裝成"callback(json)"的形式,callback為jQuery自動生成并傳到服務端的函數(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);
              }
            }

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

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

            ?思考:如果服務端已經(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)容對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)建站,關注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道,遇到問題就找創(chuàng)新互聯(lián)建站,詳細的解決方法等著你來學習!

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

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

            廣告

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

            營銷型網(wǎng)站建設

              <del id="d4fwx"><form id="d4fwx"></form></del>
              <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

                    <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
                  • 久久综合狼人 | 黄录像免费 | 一道本一区二区三区久久久久久久 | 日本a在线视频 | 欧美日本精品 |