這次帶給大家jQuery+JSONP跨域請求如何實現,實現jQuery+JSONP跨域請求的注意事項有哪些,下面就是實戰案例,一起來看一下。 JSONP(JSON with Padding)是JSON的一種“使用模式”,可用於解決主流瀏覽器的跨域資料存取的問題。由於同源策略,一般來說位於 server1.example.com 的網頁無法與不是 server1.example.com的伺服器溝通,而 HTML 的 元素是例外。利用 <script> 元素的這個開放策略,網頁可以得到從其他來源動態產生的 JSON 資料,而這個使用模式就是所謂的 JSONP。用 JSONP 抓到的資料不是 JSON,而是任意的<a href="http://www.php.cn/wiki/48.html" target="_blank">JavaScript</a>,用 JavaScript 直譯器執行而不是用 JSON 解析器解析。 </p> <p style="text-align: left;"> 上面一段話來自百度百科,概念永遠是那麼抽象難懂,看例子才是最直觀的表現。例子看的多了,領悟到那個點了,自然自己也會學著抽象的描述了。這就是為什麼常說「學習知識是從薄到厚,又由厚到薄的過程」。好了扯遠了。下面直接來看一個例子。 </p> <p style="text-align: left;"> <img alt="" src="https://img.php.cn/upload/article/000/061/021/3f2454ccbb7c73a79825cc948f18f305-0.png"></p> <p style="text-align: left;"> 問題:本地現有一個頁面demo.html需要從http://localhost:3561/User/GetAllNames取得資料並展示。 </p> <p style="text-align: left;"> 解答:由於問題中的兩方不在同一伺服器,故需要使用jsonp來跨網域存取。 </p> <p style="text-align: left;"> ① 客戶端編寫</p> <p style="text-align: left;"> <a href="http://www.php.cn/code/10550.html" target="_blank">客戶端使用</a>jQuery中提供的$.getJson方法來跨網域存取。 getJson有3個參數:</p> <p style="text-align: left;"> I. url:請求位址;</p> <p style="text-align: left;"> II. data:傳送到服務端的參數;</p> <p style="text-align: left;"># ⃀.# #回調函數<a href="http://www.php.cn/code/8530.html" target="_blank">。 </a></p> getJson的使用方法和普通的$.get方法基本上一致,不同的地方在於getJson需要在url後面的參數部分加上callback=?這一固定部分,jQuery 將自動替換? 為正確的函數名,以執行回呼函數。然後在回呼函數中操作從異域返回的json對象,回呼函數callback的參數即為該json對象。 <p style="text-align: left;"></p> <pre><!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"> $.getJSON("http://localhost:3561/User/GetAllNames?callback=?", function(json) { for (var i = 0; i < json.length; i++) { $("#nameList").append("<li>" + json[i] + "</li>"); } });