主頁 > 知識庫 > 使用$.getJSON實現(xiàn)跨域ajax請求示例代碼

使用$.getJSON實現(xiàn)跨域ajax請求示例代碼

熱門標(biāo)簽:廣西ai語音電銷機器人哪家好 信貸電銷機器人有用嗎 莆田防封電銷卡價格 電銷機器人適用范圍 蓄意標(biāo)記地圖標(biāo)注 察縣地圖標(biāo)注 辦理一個400電話多少錢 如何用地圖標(biāo)注各分公司 接聽電話機器人哪有
jQuery中常用getJSON來調(diào)用并獲取遠(yuǎn)程的JSON字符串,將其轉(zhuǎn)換為JSON對象,如果成功,則執(zhí)行回調(diào)函數(shù)。原型如下:

jQuery.getJSON( url, [data], [callback] ) 跨域加載JSON數(shù)據(jù)。

url: 發(fā)送請求的地址
data : (可選) 待發(fā)送key/value參數(shù)
callback: (可選) 載入成功時的回調(diào)函數(shù)

主要用于客戶端獲取服務(wù)器JSON數(shù)據(jù)。簡單示例:

服務(wù)器腳本,返回JSON數(shù)據(jù):

復(fù)制代碼 代碼如下:

// $.getJSON.php

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

注意兩點:第一:在返回客戶端之前,先用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ù)。同時可以注意到,經(jīng)由getJSON得到的數(shù)據(jù)已經(jīng)變成了一個對象數(shù)組,可以用response.name,response.age很直觀的獲取返回值。

jquery提供了$.getJSON的方法,讓我們可以實現(xiàn)跨域ajax請求,但jqueryAPI上的內(nèi)容實在太少,如何用$.getJSON,請求網(wǎng)站應(yīng)該返回怎樣的數(shù)據(jù)庫才能讓$.getJSON獲取到,下面我就用一個實際例子來說明下。

后端是用php的,以下代碼主要實現(xiàn)的一個功能就是提供一個預(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個為預(yù)約登記需要的參數(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_interfacename="+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("預(yù)約成功");
}
});
});

需要注意的是,在后端php代碼里,必須把傳遞進(jìn)來的" callback=? "也輸出來,如:
復(fù)制代碼 代碼如下:

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

以上就是一個簡單的$.getJSON試驗,通過這個試驗,我們可以學(xué)到如何用$.getJSON,也能學(xué)到如何做一個接口讓別人跨域請求。
您可能感興趣的文章:
  • 原生 JS Ajax,GET和POST 請求實例代碼
  • JSONP跨域GET請求解決Ajax跨域訪問問題
  • jsp+ajax發(fā)送GET請求的方法
  • ajax請求get與post的區(qū)別總結(jié)
  • jsp中 ajax的get請求的中文亂碼問題的解決方法
  • 防止ajax重復(fù)請求的方法(GET和POST)
  • 通過jquery的$.getJSON做一個跨域ajax請求試驗
  • 解決微信返回上一頁,頁面中的AJAX的請求,對Get請求無效的問題

標(biāo)簽:鷹潭 益陽 銅陵 儋州 張掖 延邊 阿拉善盟

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用$.getJSON實現(xiàn)跨域ajax請求示例代碼》,本文關(guān)鍵詞  使用,.getJSON,實現(xiàn),跨域,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用$.getJSON實現(xiàn)跨域ajax請求示例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于使用$.getJSON實現(xiàn)跨域ajax請求示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章