jquery提供了$.getJSON的方法,讓我們可以實現跨域ajax請求,但jqueryAPI上的內容實在太少,如何用$.getJSON,請求網站應該返回怎樣的資料庫才能讓$.getJSON擷取到,下面我就用一個實際例子來說明下。(主要是留個備用,怕以後再用到自己卻忘記了,所以沒有太多的解釋,實在看不明白的話,照著My Code,你也試一個吧)
我後端是用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,也能學到如何做一個介面讓別人跨域請求。
如果有疑問,可以在下面提出來,如果我哪裡寫錯了,也請幫我指出來。