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

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
Python vs. JavaScript:開發人員的比較分析Python vs. JavaScript:開發人員的比較分析May 09, 2025 am 12:22 AM

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

Python vs. JavaScript:選擇合適的工具Python vs. JavaScript:選擇合適的工具May 08, 2025 am 12:10 AM

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript:了解每個的優勢Python和JavaScript:了解每個的優勢May 06, 2025 am 12:15 AM

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

JavaScript的核心:它是在C還是C上構建的?JavaScript的核心:它是在C還是C上構建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

Python vs. JavaScript:您應該學到哪種語言?Python vs. JavaScript:您應該學到哪種語言?May 03, 2025 am 12:10 AM

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架:為現代網絡開發提供動力JavaScript框架:為現代網絡開發提供動力May 02, 2025 am 12:04 AM

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

JavaScript,C和瀏覽器之間的關係JavaScript,C和瀏覽器之間的關係May 01, 2025 am 12:06 AM

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr

See all articles

熱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

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

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

記事本++7.3.1

記事本++7.3.1

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