使用$.getJSON實現跨域ajax請求

來源:互聯網
上載者:User

jQuery中常用getJSON來調用並擷取遠端JSON字串,將其轉換為JSON對象,如果成功,則執行回呼函數。原型如下:

jQuery.getJSON( url, [data], [callback] ) 跨域載入JSON資料。

  • url: 發送請求的地址
  • data : (可選) 待發送key/value參數
  • callback: (可選) 載入成功時的回呼函數

主要用於用戶端擷取伺服器JSON資料。簡單樣本:

伺服器指令碼,返回JSON資料:

// $.getJSON.php$arr=array("name"=>"zhangsan", "age"=>20); $jarr=json_encode($arr); echo $jarr;

注意兩點:第一:在返回用戶端之前,先用PHP函數json_encode將要返回的資料進行編碼。第二:返回到用戶端用的是echo,而不是return。

下面是核心的用戶端代碼:

<script language="javascript" type="text/javascript" src="./js/jquery.js"></script> <script language="javascript" type="text/javascript"> function getjs() {   $.getJSON("$.getJSON.php", {}, function(response){                  alert(response.age);   }); } <input type="button" name="btn" id="btn" value="test" onClick="javascript:getjs();"/>

由於在PHP中是用JSON編碼傳回值,所以此處必須用getJSON去調用PHP檔案,從而擷取資料。同時可以注意到,經由getJSON得到的資料已經變成了一個對象數組,可以用response.name,response.age很直觀的擷取傳回值。

jquery提供了$.getJSON的方法,讓我們可以實現跨域ajax請求,但jqueryAPI上的內容實在太少,如何用$.getJSON,請求網站應該返回怎樣的資料庫才能讓$.getJSON擷取到,下面我就用一個實際例子來說明下。

後端是用php的,以下代碼主要實現的一個功能就是提供一個預約登記的介面,需要傳入的資料分別有:使用者姓名、聯絡電話和地址:

/*預約登記 執行 介面*/case "yuyue_interface":$name = trim($_GET['name']);$phone = trim($_GET['phone']);$addr = trim($_GET['addr']);$dt = date("Y-m-d H:i:s");$cb = $_GET['callback'];if($name == "" || $name == NULL){echo $cb."({code:".json_encode(1)."})";}elseif($phone == "" || $phone == NULL){echo $cb."({code:".json_encode(2)."})";}elseif($addr == "" || $addr == NULL){echo $cb."({code:".json_encode(3)."})";}else{$db->execute("insert into tb_yuyue (realname,telphone,danwei,dt,ischeck) values ('$name','$phone','$addr','$dt',0)");echo $cb."({code:".json_encode(0)."})";}exit;break;

接著就是前端的處理了:

$(document).ready(function(){//以下3個為預約登記需要的參數var name = "name";//varchar類型,長度最多為8位(4個漢字)var phone = "phone";//varchar類型,長度為11位var addr = "addr";//varchar類型,長度最多為500位(250個漢字)$.getJSON("http://請求網站地址/data.php?ac=yuyue_interface&name="+name+"&phone="+phone+"&addr="+addr+"&callback=?", function(data){if(data.code==1){//自訂代碼alert("姓名不可為空");}else if(data.code==2){//自訂代碼alert("手機不可為空");}else if(data.code==3){//自訂代碼alert("所在單位不可為空");}else{//自訂代碼alert("預約成功");}});});

需要注意的是,在後端php代碼裡,必須把傳遞進來的" &callback=? "也輸出來,如:

$cb = $_GET['callback'];echo $cb."({code:".json_encode(4)."})";

以上就是一個簡單的$.getJSON實驗,通過這個實驗,我們可以學到如何用$.getJSON,也能學到如何做一個介面讓別人跨域請求。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.