通過(guò)jquery的$.getJSON做一個(gè)跨域ajax請(qǐng)求試驗(yàn)
更新時(shí)間:2011年05月03日 23:00:35 作者:
jquery提供了$.getJSON的方法,讓我們可以實(shí)現(xiàn)跨域ajax請(qǐng)求,但jqueryAPI上的內(nèi)容實(shí)在太少,如何用$.getJSON,請(qǐng)求網(wǎng)站應(yīng)該返回怎樣的數(shù)據(jù)庫(kù)才能讓$.getJSON獲取到,下面我就用一個(gè)實(shí)際例子來(lái)說(shuō)明下。
(主要是留個(gè)備用,怕以后再用到自己卻忘記了,所以沒(méi)有太多的解釋?zhuān)瑢?shí)在看不明白的話,照著我的代碼,你也試一個(gè)吧)
我后端是用php的,以下代碼主要實(shí)現(xiàn)的一個(gè)功能就是提供一個(gè)預(yù)約登記的接口,需要傳入的數(shù)據(jù)分別有:用戶姓名、聯(lián)系電話和地址
/*預(yù)約登記 執(zhí)行 接口*/
/*預(yù)約登記 執(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個(gè)為預(yù)約登記需要的參數(shù)
var name = "name"; //varchar類(lèi)型,長(zhǎng)度最多為8位(4個(gè)漢字)
var phone = "phone"; //varchar類(lèi)型,長(zhǎng)度為11位
var addr = "addr"; //varchar類(lèi)型,長(zhǎng)度最多為500位(250個(gè)漢字)
$.getJSON("http://請(qǐng)求網(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("手機(jī)不能為空");
}else if(data.code==3){
//自定義代碼
alert("所在單位不能為空");
}else{
//自定義代碼
alert("預(yù)約成功");
}
});
});
需要注意的是,在后端php代碼里,必須把傳遞進(jìn)來(lái)的“ &callback=? ”也輸出來(lái),如:
$cb = $_GET['callback'];
echo $cb."({code:".json_encode(4)."})";
以上就是一個(gè)簡(jiǎn)單的$.getJSON試驗(yàn),通過(guò)這個(gè)試驗(yàn),我們可以學(xué)到如何用$.getJSON,也能學(xué)到如何做一個(gè)接口讓別人跨域請(qǐng)求。
如果有疑問(wèn),可以在下面提出來(lái),如果我哪里寫(xiě)錯(cuò)了,也請(qǐng)幫我指出來(lái)。
我后端是用php的,以下代碼主要實(shí)現(xiàn)的一個(gè)功能就是提供一個(gè)預(yù)約登記的接口,需要傳入的數(shù)據(jù)分別有:用戶姓名、聯(lián)系電話和地址
/*預(yù)約登記 執(zhí)行 接口*/
復(fù)制代碼 代碼如下:
/*預(yù)約登記 執(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;
接著就是前端的處理了
復(fù)制代碼 代碼如下:
$(document).ready(function(){
//以下3個(gè)為預(yù)約登記需要的參數(shù)
var name = "name"; //varchar類(lèi)型,長(zhǎng)度最多為8位(4個(gè)漢字)
var phone = "phone"; //varchar類(lèi)型,長(zhǎng)度為11位
var addr = "addr"; //varchar類(lèi)型,長(zhǎng)度最多為500位(250個(gè)漢字)
$.getJSON("http://請(qǐng)求網(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("手機(jī)不能為空");
}else if(data.code==3){
//自定義代碼
alert("所在單位不能為空");
}else{
//自定義代碼
alert("預(yù)約成功");
}
});
});
需要注意的是,在后端php代碼里,必須把傳遞進(jìn)來(lái)的“ &callback=? ”也輸出來(lái),如:
復(fù)制代碼 代碼如下:
$cb = $_GET['callback'];
echo $cb."({code:".json_encode(4)."})";
以上就是一個(gè)簡(jiǎn)單的$.getJSON試驗(yàn),通過(guò)這個(gè)試驗(yàn),我們可以學(xué)到如何用$.getJSON,也能學(xué)到如何做一個(gè)接口讓別人跨域請(qǐng)求。
如果有疑問(wèn),可以在下面提出來(lái),如果我哪里寫(xiě)錯(cuò)了,也請(qǐng)幫我指出來(lái)。
相關(guān)文章
jQuery操作attr、prop、val()/text()/html()、class屬性
這篇文章主要介紹了jQuery操作attr、prop、val()/text()/html()、class屬性 ,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05jquery ui dialog ie8出現(xiàn)滾動(dòng)條的解決方法
jquery ui 的 dialog 在IE8下會(huì)出現(xiàn)不該出現(xiàn)的滾動(dòng)條,在JQUI的FORUM上SEARCH下,發(fā)現(xiàn)也有人碰上,當(dāng)解決辦法就是把滾動(dòng)條隱藏2010-12-12a標(biāo)簽跳轉(zhuǎn)到指定div,jquery添加和移除class屬性的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇a標(biāo)簽跳轉(zhuǎn)到指定div,jquery添加和移除class屬性的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10JQuery Ajax執(zhí)行跨域請(qǐng)求數(shù)據(jù)的解決方案
今天小編就為大家分享一篇關(guān)于JQuery Ajax執(zhí)行跨域請(qǐng)求數(shù)據(jù)的解決方案,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12實(shí)例詳解jQuery的鏈?zhǔn)骄幊田L(fēng)格
jQuery中的鏈?zhǔn)讲僮?,它讓代碼變得更有層次更簡(jiǎn)潔,所以這篇文章主要給大家介紹了關(guān)于jQuery鏈?zhǔn)骄幊田L(fēng)格的相關(guān)資料,需要的朋友可以參考下2021-06-06jQuery 數(shù)據(jù)緩存data(name, value)詳解及實(shí)現(xiàn)
本文要討論的是最流行的JavaScript框架jQuery的數(shù)據(jù)緩存實(shí)現(xiàn)原理,這是jQuery1.2.3版開(kāi)始加入的新功能。2010-01-01