通過jquery的$.getJSON做一個跨域ajax請求試驗
更新時間:2011年05月03日 23:00:35 作者:
jquery提供了$.getJSON的方法,讓我們可以實現(xiàn)跨域ajax請求,但jqueryAPI上的內(nèi)容實在太少,如何用$.getJSON,請求網(wǎng)站應該返回怎樣的數(shù)據(jù)庫才能讓$.getJSON獲取到,下面我就用一個實際例子來說明下。
(主要是留個備用,怕以后再用到自己卻忘記了,所以沒有太多的解釋,實在看不明白的話,照著我的代碼,你也試一個吧)
我后端是用php的,以下代碼主要實現(xiàn)的一個功能就是提供一個預約登記的接口,需要傳入的數(shù)據(jù)分別有:用戶姓名、聯(lián)系電話和地址
/*預約登記 執(zhí)行 接口*/
/*預約登記 執(zhí)行 接口*/
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個為預約登記需要的參數(shù)
var name = "name"; //varchar類型,長度最多為8位(4個漢字)
var phone = "phone"; //varchar類型,長度為11位
var addr = "addr"; //varchar類型,長度最多為500位(250個漢字)
$.getJSON("http://請求網(wǎng)站地址/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,也能學到如何做一個接口讓別人跨域請求。
如果有疑問,可以在下面提出來,如果我哪里寫錯了,也請幫我指出來。
我后端是用php的,以下代碼主要實現(xiàn)的一個功能就是提供一個預約登記的接口,需要傳入的數(shù)據(jù)分別有:用戶姓名、聯(lián)系電話和地址
/*預約登記 執(zhí)行 接口*/
復制代碼 代碼如下:
/*預約登記 執(zhí)行 接口*/
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個為預約登記需要的參數(shù)
var name = "name"; //varchar類型,長度最多為8位(4個漢字)
var phone = "phone"; //varchar類型,長度為11位
var addr = "addr"; //varchar類型,長度最多為500位(250個漢字)
$.getJSON("http://請求網(wǎng)站地址/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,也能學到如何做一個接口讓別人跨域請求。
如果有疑問,可以在下面提出來,如果我哪里寫錯了,也請幫我指出來。
相關文章
jquery中常用的SET和GET$(”#msg”).html循環(huán)介紹
jquery中常用的SET和GET$(”#msg”).html循環(huán)想必大家并不陌生吧,本文整理了一些,感興趣的朋友可以參考下2013-10-10
jquery實現(xiàn)隱藏與顯示動畫效果/輸入框字符動態(tài)遞減/導航按鈕切換
jquery實現(xiàn)隱藏顯示層動畫效果、仿新浪字符動態(tài)輸入、tab效果等等,以下為所有代碼,感興趣的朋友可以練練手哈,希望對大家學習有所幫助2013-07-07
jquery實現(xiàn)手機端單店鋪購物車結(jié)算刪除功能
本文主要介紹了js實現(xiàn)手機端單店鋪購物車結(jié)算刪除功能的示例代碼,具有很好的參考價值,下面跟著小編一起來看下吧2017-02-02
jQuery實現(xiàn)為table表格動態(tài)添加或刪除tr功能示例
這篇文章主要介紹了jQuery實現(xiàn)為table表格動態(tài)添加或刪除tr功能,結(jié)合實例形式分析了jQuery針對table表格行動態(tài)操作相關實現(xiàn)技巧,需要的朋友可以參考下2019-02-02
Jquery倒數(shù)計時按鈕setTimeout的實例代碼
這篇文章介紹了Jquery倒數(shù)計時按鈕setTimeout的實例,有需要的朋友可以參考一下2013-07-07

