欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jquery的$getjson調(diào)用并獲取遠(yuǎn)程的JSON字符串問題

 更新時間:2012年12月10日 09:48:04   作者:  
jQuery中常用getJSON來調(diào)用并獲取遠(yuǎn)程的JSON字符串,將其轉(zhuǎn)換為JSON對象,如果成功,則執(zhí)行回調(diào)函數(shù),本文將詳細(xì)介紹,需要的朋友可以參考下
代碼如下:
復(fù)制代碼 代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標(biāo)題文檔</title>
</head>
<script type="text/javascript" src="jquery-1.7.2.min.js"></script>
<script type="text/javascript">
$(function(){
$("button").click(function(){
$.getJSON("ajax6.asp",function(data){
$("#pig").html(data.name);
});
});
});
</script>
<body>
<button>click</button>
<div id="pig"></div>
</body>
</html>

其中ajax6.asp為
復(fù)制代碼 代碼如下:

<%
response.Write(“{name:'peter',age:18}”);
%>

為什么獲取不了呢?,我想獲取asp的json。
解決的關(guān)鍵問題是:key和value需要雙引號,如下:
復(fù)制代碼 代碼如下:

response.Write(“{“”name”":”"peter”",”"age”":”"18″”}”)

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;

注意兩點(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ù)。同時可以注意到,經(jīng)由getJSON得到的數(shù)據(jù)已經(jīng)變成了一個對象數(shù)組,可以用response.name,response.age很直觀的獲取返回值。
jquery提供了$.getJSON的方法,讓我們可以實(shí)現(xiàn)跨域ajax請求,但jqueryAPI上的內(nèi)容實(shí)在太少,如何用$.getJSON,請求網(wǎng)站應(yīng)該返回怎樣的數(shù)據(jù)庫才能讓$.getJSON獲取到,下面我就用一個實(shí)際例子來說明下。
后端是用php的,以下代碼主要實(shí)現(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_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)來的" &callback=? "也輸出來,如:
復(fù)制代碼 代碼如下:

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

以上就是一個簡單的$.getJSON試驗(yàn),通過這個試驗(yàn),我們可以學(xué)到如何用$.getJSON,也能學(xué)到如何做一個接口讓別人跨域請求。

相關(guān)文章

  • Three.js后期處理效果(發(fā)光描邊OutlinePass)

    Three.js后期處理效果(發(fā)光描邊OutlinePass)

    這篇文章主要給大家介紹了關(guān)于Three.js后期處理效果(發(fā)光描邊OutlinePass)的相關(guān)資料,Three js 開發(fā)的一些知識整理,方便后期遇到類似的問題,能夠及時查閱使用,需要的朋友可以參考下
    2024-01-01
  • js實(shí)現(xiàn)的定時關(guān)閉頁面或定時提醒效果代碼

    js實(shí)現(xiàn)的定時關(guān)閉頁面或定時提醒效果代碼

    比較有創(chuàng)意的定時關(guān)閉頁面或定時提醒效果代碼
    2008-02-02
  • Typescript的三種運(yùn)行方式(小結(jié))

    Typescript的三種運(yùn)行方式(小結(jié))

    這篇文章主要介紹了Typescript的三種運(yùn)行方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • 你不知道的高性能JAVASCRIPT

    你不知道的高性能JAVASCRIPT

    想必大家都知道,JavaScrip是全棧開發(fā)語言,瀏覽器,手機(jī),服務(wù)器端都可以看到JS的身影。 本文會分享一些高效的JavaScript的最佳實(shí)踐,提高大家對JS的底層和實(shí)現(xiàn)原理的理解,感興趣的小伙伴們可以參考一下
    2016-01-01
  • js獲取html的span標(biāo)簽的值方法(超簡單)

    js獲取html的span標(biāo)簽的值方法(超簡單)

    下面小編就為大家?guī)硪黄猨s獲取html的span標(biāo)簽的值方法(超簡單)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • JS+CSS實(shí)現(xiàn)帶關(guān)閉按鈕DIV彈出窗口的方法

    JS+CSS實(shí)現(xiàn)帶關(guān)閉按鈕DIV彈出窗口的方法

    這篇文章主要介紹了JS+CSS實(shí)現(xiàn)帶關(guān)閉按鈕DIV彈出窗口的方法,實(shí)例分析了div彈出層窗口的實(shí)現(xiàn)技巧,非常具有實(shí)用價值,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-02-02
  • javascript CSS畫圖之基礎(chǔ)篇

    javascript CSS畫圖之基礎(chǔ)篇

    要在瀏覽器上動態(tài)地畫圖(矢量圖),個人覺得矢量圖中最關(guān)鍵的兩點(diǎn).
    2009-07-07
  • js實(shí)現(xiàn)拖拽上傳圖片功能

    js實(shí)現(xiàn)拖拽上傳圖片功能

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)拖拽上傳圖片功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 使用js獲取圖片原始尺寸

    使用js獲取圖片原始尺寸

    本文給大家推薦的是一個使用js獲取圖片的原始尺寸的例子,從本人項(xiàng)目中摳出來的,這里奉獻(xiàn)給大家,有需要的直接拿走。
    2014-12-12
  • ECharts數(shù)據(jù)可視化基本使用之常用圖表類型

    ECharts數(shù)據(jù)可視化基本使用之常用圖表類型

    這篇文章主要給大家介紹了關(guān)于ECharts數(shù)據(jù)可視化基本使用之常用圖表類型的相關(guān)資料,echarts是一款基于JavaScript的數(shù)據(jù)可視化圖表庫,提供直觀,生動,可交互,可個性化定制的數(shù)據(jù)可視化圖表,需要的朋友可以參考下
    2023-11-11

最新評論