亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用$.getJSON實現跨域ajax請求

發布時間:2021-07-24 14:34:34 來源:億速云 閱讀:140 作者:chen 欄目:web開發

本篇內容主要講解“如何使用$.getJSON實現跨域ajax請求”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何使用$.getJSON實現跨域ajax請求”吧!

jQuery中常用getJSON來調用并獲取遠程的JSON字符串,將其轉換為JSON對象,如果成功,則執行回調函數。原型如下:

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

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

主要用于客戶端獲取服務器JSON數據。簡單示例:

服務器腳本,返回JSON數據:

復制代碼 代碼如下:


// $.getJSON.php

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


注意兩點:第一:在返回客戶端之前,先用PHP函數json_encode將要返回的數據進行編碼。第二:返回到客戶端用的是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去調用PHP文件,從而獲取數據。同時可以注意到,經由getJSON得到的數據已經變成了一個對象數組,可以用response.name,response.age很直觀的獲取返回值。

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

后端是用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,也能學到如何做一個接口讓別人跨域請求。

到此,相信大家對“如何使用$.getJSON實現跨域ajax請求”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

通州市| 依兰县| 鄂托克旗| 和田市| 陈巴尔虎旗| 黔南| 正蓝旗| 柘荣县| 兴和县| 微博| 和田市| 祁东县| 光泽县| 石河子市| 焉耆| 福鼎市| 横山县| 正阳县| 吐鲁番市| 老河口市| 宽甸| 岳西县| 英德市| 密云县| 珲春市| 荃湾区| 宜君县| 望谟县| 临沧市| 天门市| 台山市| 桃源县| 三门县| 牙克石市| 手机| 雷山县| 瑞金市| 抚顺市| 清涧县| 连云港市| 高雄县|