首頁 web前端 js教程 淺談JSON和JSONP區別及jQuery的ajax jsonp的使用_jquery

淺談JSON和JSONP區別及jQuery的ajax jsonp的使用_jquery

May 16, 2016 pm 04:30 PM
jquery json jsonp

JSON和JSONP
 
  JSON(JavaScript Object Notation)是一種輕量級的資料交換格式,用於在瀏覽器和伺服器之間交換資訊。
 
  JSONP(JSON With Padding),就是打包在函數呼叫中的的JSON(或者包裹的JSON)。
 
  JSON是一種資料格式,JSONP是一種資料呼叫方式。
 

複製程式碼 程式碼如下:

 //JSON
 {
 「name」: “sb”
 }

複製程式碼 程式碼如下:

 //JSONP
 callback({
 「name」: “sb”
 })

  出於安全考慮,腳本(AJAX)不能存取非本域的內容。但是,靜態資源是不受域策略限制的,可以載入任意域的腳本、樣式、圖片等靜態資源,JSOP就是利用這種原理來實現跨域取得資料的。
 
例1:

複製程式碼 程式碼如下:

 //定義shoPrice函數
 function showPrice(data) {
     alert("Symbol: " data.symbol ", Price: " data.price);
 }

複製程式碼 程式碼如下:

 //在Web頁中包含showPrice函數和參數
 
 

  本例展示如何將靜態JSON資料作為參數呼叫JavaScript函數。
 
 例2:
 
  第一種的函數呼叫完全可以寫在一個js檔案中放在伺服器上,用script標籤載入到頁面,而且這個標籤可以動態地建立。
 

複製程式碼 程式碼如下:

 

remote.js的內容和之前在標籤裡寫的一樣是:
 
 1 showPrice({symbol: 'IBM', price: 91.42});
 
  動態插入的JavaScript程式碼,將要傳遞的JSON資料作為參數,showPrice函數呼叫語句的參數。
 
  那麼問題來了,每次取得到資料都呼叫showPrice函數嗎?這就需要前後端程式猿人做好約定,當然這樣有很多不便,尤其是對於開放介面給大眾開發的情況。 JSOP這樣處理:支援前端傳遞一個回呼函數名參數,後端接收回呼函數名參數,然後產生對該函數的調用,將JSON資料作為參數傳遞,在到達客戶端時將其插入頁面開始執行。
 
例3:
 
  動態插入程式碼,帶有callback參數:
 

複製程式碼 程式碼如下:

 

後端用PHP實作的JSONP服務的程式碼片段:
 

複製程式碼 程式碼如下:

 $jsonData = getDataAsJson($_GET['symbol']);
 echo $_GET['callback'] . '(' . $jsonData . ');';
 // 列印: showPrice({"symbol" : "IBM", "price" : "91.42"});

很好的契合了JSONP的定義,打包在函數呼叫中的JSON資料。
 
以上幾個例子來自:
 
使用 JSONP 實現跨域通信,第 1 部分: 結合 JSONP 和 jQuery 快速構建強大的 mashup
 
在jQuery使用JSONP
 
  AJAX和JSONP在jQuery中的調用方式看起來極為相像,千萬不要被這種現象迷惑,它們本質上有很大不同。 AJAX是透過XMLHttpRequest物件取得非頁面內容,而JSONP是動態的新增<script>標籤來呼叫伺服器腳本。雖然jQuery把JSONP作為AJAX的一種形式進行了封裝,但JSONP並不是AJAX的一種形式或一種特例。 <br />  <br /> <div class="codetitle"><span><a style="CURSOR: pointer" data="8779" class="copybut" id="copybut8779" onclick="doCopy('code8779')"><U>複製程式碼 程式碼如下:<div class="codebody" id="code8779"><br />  $.ajax({<br />      url: "<a href="http://query.yahooapis.com/v1/public/yql">http://query.yahooapis.com/v1/public/yql",<br />      jsonpCallback: "showPrice",<br />      jsonp: "callback",<br />      // tell jQuery we're expecting JSONP<br />      dataType: "jsonp",<br />      data: {<br />          q: "select title,abstract,url from search.news where query="cat"",<br />          format: "json"<br />      },<br />      // work with the response<br />      success: function( data ) {<br />          console.log( data ); // server response<br />      }<br />  });<br /> <p>ajax請求參數說明: <p><strong>dataType  String <p>預期伺服器傳回的資料類型。如果不指定,jQuery 會自動根據 HTTP 套件 MIME 資訊來智慧判斷,例如XML MIME類型就被辨識為XML。在1.4中,JSON就會產生一個JavaScript對象,而script則會執行這個腳本。隨後伺服器端傳回的資料會根據這個值解析後,傳遞給回呼函數。可用值: <p>"xml": 傳回 XML 文檔,可用 jQuery 處理。 <p>"html": 傳回純文字 HTML 資訊;所包含的script標籤會在插入dom時執行。 <p>"script": 傳回純文字 JavaScript 程式碼。不會自動快取結果。除非設定了"cache"參數。 '''注意:'''在遠端請求時(不在同一個網域下),所有POST請求都會轉為GET請求。 (因為將使用DOM的script標籤來載入) <p>"json": 傳回 JSON 資料 。 <p>"jsonp": JSONP 格式。使用 JSONP 形式呼叫函數時,如 "myurl?callback=?" jQuery 會自動取代 ? 為正確的函式名,以執行回呼函數。 <p>"text": 傳回純文字字串<br />  <br /> <strong>jsonp,<br />  <br />   重寫jsonp請求中的回呼函數的名稱。至俄格值用來取代「callback=?」這種GET或POST請求URL參數裡的「callback」部分,例如{jsonp:'onJsonPLoad'}會導致「onJsonPLoad」傳遞給伺服器。 <br />  <br /> <strong>jsonpCallback,<br />  <br />   為jsonp指定一個回呼函數名。這個值將會用來取代jQuery自動產生的隨機函數名。這主要用來讓jQuery產生度獨特的函數名,這樣管理請求更容易,也能方便地提供回呼函數和錯誤處理。你也可以在想讓瀏覽器快取GET請求的時候,指定這個回呼函數名稱。但是實際使用過程中,並不用寫回調函數,比如此例中的showPrice,不寫也不會報錯,因為jQuery在處理JSONP的時候,自動幫你產生回調函數並且把資料取出來共success方法呼叫。可能像這樣: <p><div class="codetitle"><span><a style="CURSOR: pointer" data="75667" class="copybut" id="copybut75667" onclick="doCopy('code75667')"><U>複製程式碼 程式碼如下:<div class="codebody" id="code75667"><br />  function success_jsonpCallback(data) { success(data); }  <br /> <p>以上就是本文的全部內容了,大家是否對jsonp有了細緻的了解呢。有什麼疑問也請給我留言,大家共同探討。 </script>
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1317
25
PHP教程
1268
29
C# 教程
1246
24
PHP 數組轉 JSON 的效能最佳化技巧 PHP 數組轉 JSON 的效能最佳化技巧 May 04, 2024 pm 06:15 PM

PHP數組轉JSON的效能最佳化方法包括:使用JSON擴充和json_encode()函數;新增JSON_UNESCAPED_UNICODE選項以避免字元轉義;使用緩衝區提高循環編碼效能;快取JSON編碼結果;考慮使用第三方JSON編碼庫。

Jackson庫中註解如何控制JSON序列化和反序列化? Jackson庫中註解如何控制JSON序列化和反序列化? May 06, 2024 pm 10:09 PM

Jackson庫中的註解可控制JSON序列化和反序列化:序列化:@JsonIgnore:忽略屬性@JsonProperty:指定名稱@JsonGetter:使用獲取方法@JsonSetter:使用設定方法反序列化:@JsonIgnoreProperties:忽略屬性@ JsonProperty:指定名稱@JsonCreator:使用建構子@JsonDeserialize:自訂邏輯

深入了解PHP:JSON Unicode轉中文的實作方法 深入了解PHP:JSON Unicode轉中文的實作方法 Mar 05, 2024 pm 02:48 PM

深入了解PHP:JSONUnicode轉中文的實作方法在開發中,我們經常會遇到需要處理JSON資料的情況,而JSON中的Unicode編碼在一些場景下會為我們帶來一些問題,特別是當需要將Unicode編碼轉換為中文字元時。在PHP中,有一些方法可以幫助我們實現這個轉換過程,以下將介紹常用的方法,並提供具體的程式碼範例。首先,讓我們先來了解一下JSON中Un

如何使用 PHP 函數處理 JSON 資料? 如何使用 PHP 函數處理 JSON 資料? May 04, 2024 pm 03:21 PM

PHP提供了以下函數來處理JSON資料:解析JSON資料:使用json_decode()將JSON字串轉換為PHP數組。建立JSON資料:使用json_encode()將PHP陣列或物件轉換為JSON字串。取得JSON資料的特定值:使用PHP數組函數存取特定值,例如鍵值對或陣列元素。

PHP 數組轉 JSON 的快捷技巧 PHP 數組轉 JSON 的快捷技巧 May 03, 2024 pm 06:33 PM

PHP陣列可透過json_encode()函數轉換為JSON字串(例如:$json=json_encode($array);),反之亦可用json_decode()函數從JSON轉換為陣列($array=json_decode($json);) 。其他技巧還包括:避免深度轉換、指定自訂選項以及使用第三方程式庫。

如何在 Golang 中將 JSON 資料保存到資料庫中? 如何在 Golang 中將 JSON 資料保存到資料庫中? Jun 06, 2024 am 11:24 AM

可以透過使用gjson函式庫或json.Unmarshal函數將JSON資料儲存到MySQL資料庫中。 gjson函式庫提供了方便的方法來解析JSON字段,而json.Unmarshal函數需要一個目標類型指標來解組JSON資料。這兩種方法都需要準備SQL語句和執行插入操作來將資料持久化到資料庫中。

如何判斷jQuery元素是否具有特定屬性? 如何判斷jQuery元素是否具有特定屬性? Feb 29, 2024 am 09:03 AM

如何判斷jQuery元素是否具有特定屬性?在使用jQuery操作DOM元素時,常會遇到需要判斷元素是否具有某個特定屬性的情況。在這種情況下,我們可以藉助jQuery提供的方法來輕鬆實現這項功能。以下將介紹兩種常用的方法來判斷一個jQuery元素是否具有特定屬性,並附上具體的程式碼範例。方法一:使用attr()方法和typeof運算子//判斷元素是否具有特定屬

使用jQuery為表格新增一行的方法介紹 使用jQuery為表格新增一行的方法介紹 Feb 29, 2024 am 08:12 AM

jQuery是一個受歡迎的JavaScript函式庫,廣泛用於網頁開發。在網頁開發過程中,經常需要透過JavaScript動態地在表格中新增一行。本文將介紹如何使用jQuery為表格新增一行,並提供具體的程式碼範例。首先,我們需要在HTML頁面中引入jQuery函式庫。可以透過以下程式碼在標籤中引入jQuery庫:

See all articles