国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > AJAX > 正文

jquery跨域請求示例分享(jquery發(fā)送ajax請求)

2024-09-01 08:32:38
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了jquery跨域請求示例(jquery發(fā)送ajax請求),需要的朋友可以參考下

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

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

url: 發(fā)送請求的地址
data : (可選) 待發(fā)送key/value參數(shù)
callback: (可選) 載入成功時的回調函數(shù)
主要用于客戶端獲取服務器JSON數(shù)據。簡單示例:

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

復制代碼 代碼如下:


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

注意兩點:第一:在返回客戶端之前,先用PHP函數(shù)json_encode將要返回的數(shù)據進行編碼。第二:返回到客戶端用的是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" value="test"/>

由于在PHP中是用JSON編碼返回值,所以此處必須用getJSON去調用PHP文件,從而獲取數(shù)據。同時可以注意到,經由getJSON得到的數(shù)據已經變成了一個對象數(shù)組,可以用response.name,response.age很直觀的獲取返回值。

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

后端是用php的,以下代碼主要實現(xiàn)的一個功能就是提供一個預約登記的接口,需要傳入的數(shù)據分別有:用戶姓名、聯(lián)系電話和地址:

復制代碼 代碼如下:


/*預約登記 執(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://請求網站地址/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,也能學到如何做一個接口讓別人跨域請求。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 翁源县| 板桥市| 固阳县| 富川| 蒙阴县| 五河县| 昌乐县| 台北市| 犍为县| 潼关县| 巩留县| 富源县| 苍山县| 修水县| 双鸭山市| 巴中市| 沾益县| 青川县| 六安市| 元朗区| 齐河县| 芦山县| 体育| 河南省| 南川市| 安塞县| 开阳县| 都匀市| 涞源县| 盐山县| 图木舒克市| 泊头市| 庆安县| 育儿| 新龙县| 襄垣县| 汝南县| 都江堰市| 广西| 遵化市| 达拉特旗|