使用$.getJSON實(shí)現(xiàn)跨域ajax請(qǐng)求示例代碼
更新時(shí)間:2013年11月26日 17:17:44 作者:
getJSON調(diào)用并獲取遠(yuǎn)程的JSON字符串,將其轉(zhuǎn)換為JSON對(duì)象,如果成功,則執(zhí)行回調(diào)函數(shù),下面有個(gè)不錯(cuò)的示例,需要的朋友可以參考下
jQuery中常用getJSON來(lái)調(diào)用并獲取遠(yuǎn)程的JSON字符串,將其轉(zhuǎn)換為JSON對(duì)象,如果成功,則執(zhí)行回調(diào)函數(shù)。原型如下:
jQuery.getJSON( url, [data], [callback] ) 跨域加載JSON數(shù)據(jù)。
url: 發(fā)送請(qǐng)求的地址
data : (可選) 待發(fā)送key/value參數(shù)
callback: (可選) 載入成功時(shí)的回調(diào)函數(shù)
主要用于客戶端獲取服務(wù)器JSON數(shù)據(jù)。簡(jiǎn)單示例:
服務(wù)器腳本,返回JSON數(shù)據(jù):
// $.getJSON.php
$arr=array("name"=>"zhangsan", "age"=>20);
$jarr=json_encode($arr);
echo $jarr;
注意兩點(diǎn):第一:在返回客戶端之前,先用PHP函數(shù)json_encode將要返回的數(shù)據(jù)進(jìn)行編碼。第二:返回到客戶端用的是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去調(diào)用PHP文件,從而獲取數(shù)據(jù)。同時(shí)可以注意到,經(jīng)由getJSON得到的數(shù)據(jù)已經(jīng)變成了一個(gè)對(duì)象數(shù)組,可以用response.name,response.age很直觀的獲取返回值。
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ō)明下。
后端是用php的,以下代碼主要實(shí)現(xiàn)的一個(gè)功能就是提供一個(gè)預(yù)約登記的接口,需要傳入的數(shù)據(jù)分別有:用戶姓名、聯(lián)系電話和地址:
/*預(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類型,長(zhǎng)度最多為8位(4個(gè)漢字)
var phone = "phone"; //varchar類型,長(zhǎng)度為11位
var addr = "addr"; //varchar類型,長(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)求。
jQuery.getJSON( url, [data], [callback] ) 跨域加載JSON數(shù)據(jù)。
url: 發(fā)送請(qǐng)求的地址
data : (可選) 待發(fā)送key/value參數(shù)
callback: (可選) 載入成功時(shí)的回調(diào)函數(shù)
主要用于客戶端獲取服務(wù)器JSON數(shù)據(jù)。簡(jiǎn)單示例:
服務(wù)器腳本,返回JSON數(shù)據(jù):
復(fù)制代碼 代碼如下:
// $.getJSON.php
$arr=array("name"=>"zhangsan", "age"=>20);
$jarr=json_encode($arr);
echo $jarr;
注意兩點(diǎn):第一:在返回客戶端之前,先用PHP函數(shù)json_encode將要返回的數(shù)據(jù)進(jìn)行編碼。第二:返回到客戶端用的是echo,而不是return。
下面是核心的客戶端代碼:
復(fù)制代碼 代碼如下:
<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去調(diào)用PHP文件,從而獲取數(shù)據(jù)。同時(shí)可以注意到,經(jīng)由getJSON得到的數(shù)據(jù)已經(jīng)變成了一個(gè)對(duì)象數(shù)組,可以用response.name,response.age很直觀的獲取返回值。
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ō)明下。
后端是用php的,以下代碼主要實(shí)現(xiàn)的一個(gè)功能就是提供一個(gè)預(yù)約登記的接口,需要傳入的數(shù)據(jù)分別有:用戶姓名、聯(lián)系電話和地址:
復(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類型,長(zhǎng)度最多為8位(4個(gè)漢字)
var phone = "phone"; //varchar類型,長(zhǎng)度為11位
var addr = "addr"; //varchar類型,長(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)求。
您可能感興趣的文章:
- 原生 JS Ajax,GET和POST 請(qǐng)求實(shí)例代碼
- JSONP跨域GET請(qǐng)求解決Ajax跨域訪問(wèn)問(wèn)題
- jsp+ajax發(fā)送GET請(qǐng)求的方法
- ajax請(qǐng)求get與post的區(qū)別總結(jié)
- jsp中 ajax的get請(qǐng)求的中文亂碼問(wèn)題的解決方法
- 防止ajax重復(fù)請(qǐng)求的方法(GET和POST)
- 通過(guò)jquery的$.getJSON做一個(gè)跨域ajax請(qǐng)求試驗(yàn)
- 解決微信返回上一頁(yè),頁(yè)面中的AJAX的請(qǐng)求,對(duì)Get請(qǐng)求無(wú)效的問(wèn)題
相關(guān)文章
ajax動(dòng)態(tài)查詢數(shù)據(jù)庫(kù)數(shù)據(jù)并顯示在前臺(tái)的方法
今天小編就為大家分享一篇ajax動(dòng)態(tài)查詢數(shù)據(jù)庫(kù)數(shù)據(jù)并顯示在前臺(tái)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08AJAX實(shí)現(xiàn)注冊(cè)驗(yàn)證用戶名
這篇文章主要為大家詳細(xì)介紹了AJAX實(shí)現(xiàn)注冊(cè)驗(yàn)證用戶名,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-03-03ajax.js里面有內(nèi)容顯示效果,根據(jù)ID
ajax.js里面有內(nèi)容顯示效果,根據(jù)ID...2006-10-10jQuery+Ajax+PHP實(shí)現(xiàn)“喜歡”評(píng)級(jí)功能附源碼下載
有同學(xué)問(wèn)我如何實(shí)現(xiàn)一個(gè)像美麗說(shuō)那樣的“我喜歡”評(píng)級(jí)功能,當(dāng)用戶看到自己喜歡的圖片或文章時(shí),點(diǎn)擊“紅心”按鈕,系統(tǒng)會(huì)自動(dòng)記錄用戶的點(diǎn)擊,并將總數(shù)加1。這樣再結(jié)合不同的系統(tǒng),可以將此功能應(yīng)用到投票或收藏商品中去(如淘寶的收藏商品)。2015-10-10Ajax獲取響應(yīng)內(nèi)容長(zhǎng)度的方法
這篇文章主要介紹了Ajax獲取響應(yīng)內(nèi)容長(zhǎng)度的方法,涉及Ajax調(diào)用成功后返回方法的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07ajax原理總結(jié)附簡(jiǎn)單實(shí)例及其優(yōu)點(diǎn)
在工作中用了Ajax N多次了,也看過(guò)一些相關(guān)方面的書籍,也算是認(rèn)識(shí)了它,本文對(duì)ajax原理坐下總結(jié),需要的朋友可以參考下2014-04-04ajax動(dòng)態(tài)加載json數(shù)據(jù)并詳細(xì)解析
今天小編就為大家分享一篇ajax動(dòng)態(tài)加載json數(shù)據(jù)并詳細(xì)解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08