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

首頁(yè) > 開(kāi)發(fā) > AJAX > 正文

jQuery通過(guò)Ajax返回JSON數(shù)據(jù)

2024-09-01 08:33:30
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

最近在使用JQuery的ajax方法時(shí),要求返回的數(shù)據(jù)為json數(shù)據(jù),在處理的過(guò)程中遇到下面的幾個(gè)問(wèn)題,那就是采用不同的方式來(lái)生成json數(shù)據(jù)的時(shí)候,在$.ajax方法中應(yīng)該是如何來(lái)處理的,下面依次來(lái)進(jìn)行說(shuō)明。

服務(wù)端PHP讀取MYSQL數(shù)據(jù),并轉(zhuǎn)換成JSON數(shù)據(jù),傳遞給前端Javascript,并操作JSON數(shù)據(jù)。本文將通過(guò)實(shí)例演示了jQuery通過(guò)Ajax向PHP服務(wù)端發(fā)送請(qǐng)求并返回JSON數(shù)據(jù)。

JSON(JavaScript Object Notation) 是一種輕量級(jí)的數(shù)據(jù)交換格式。易于人閱讀和編寫(xiě),同時(shí)也易于機(jī)器解析和生成。JSON在前后臺(tái)交互的過(guò)程中發(fā)揮著相當(dāng)出色的作用。請(qǐng)接著往下看教程。

 

 
  1. <ul id="userlist">  
  2. <li><a href="#" rel="1">張三</a></li>  
  3. <li><a href="#" rel="2">李四</a></li>  
  4. <li><a href="#" rel="3">王五</a></li>  
  5. </ul>  
  6. <div id="info">  
  7. <p>姓名:<span id="name"></span></p>  
  8. <p>性別:<span id="sex"></span></p>  
  9. <p>電話:<span id="tel"></span></p>  
  10. <p>郵箱:<span id="email"></span></p>  
  11. </div>  

實(shí)例中,顯示了一個(gè)用戶姓名列表ul#userlist,一個(gè)用戶詳細(xì)信息層#info。值得注意的是,我給每個(gè)標(biāo)簽設(shè)置屬性“rel”并賦值,這個(gè)很重要,將在jQuery中使用。我要實(shí)現(xiàn)的效果就是:當(dāng)點(diǎn)擊用戶列表中任意用戶的姓名,將即時(shí)顯示出該用戶的詳細(xì)信息,如電話、EMAIL等。

CSS

 

 
  1. #userlist{margin:4pxheight:42px}  
  2. #userlist li{float:leftwidth:80pxline-height:42pxheight:42pxfont-size:14px;  
  3. font-weight:bold}  
  4. #info{clear:leftpadding:6pxborder:1px solid #b6d6e6background:#e8f5fe}  
  5. #info p{line-height:24px}  
  6. #info p span{font-weight:bold}  

CSS設(shè)置了用戶列表和用戶詳細(xì)信息的顯示外觀,您也可以自己設(shè)計(jì)一個(gè)好看的外觀。

jQuery

使用jQuery前,別忘了先要確保載入的jQuery庫(kù)。

接下來(lái)開(kāi)始寫(xiě)jQuery代碼了。

 

 
  1. $(function(){  
  2. $("#userlist a").bind("click",function(){  
  3. var hol = $(this).attr("rel");  
  4. var data = "action=getlink&id="+hol;  
  5.  
  6. $.getJSON("server.php",data, function(json){  
  7. $("#name").html(json.name);  
  8. $("#sex").html(json.sex);  
  9. $("#tel").html(json.tel);  
  10. $("#email").html(json.email);  
  11. });  
  12. });  
  13. });  

我給用戶列表的每個(gè)標(biāo)簽都綁定一個(gè)click事件,當(dāng)單擊用戶姓名時(shí),執(zhí)行以下操作:獲取當(dāng)前標(biāo)簽的屬性“rel”的值,并組成一個(gè)數(shù)據(jù)串:var data = "action=getlink&id="+hol,接著通過(guò)ajax向服務(wù)端server.php發(fā)送JSON請(qǐng)求,得到后臺(tái)響應(yīng)后,返回JSON數(shù)據(jù),并將得到的數(shù)據(jù)顯示在用戶詳細(xì)信息中。

PHP

后臺(tái)server.php得到前端的Ajax請(qǐng)求后,通過(guò)傳遞的參數(shù)連接數(shù)據(jù)庫(kù)并查詢用戶表,將相應(yīng)的用戶信息轉(zhuǎn)換成一個(gè)數(shù)組$list,最后將數(shù)組轉(zhuǎn)換成JSON數(shù)據(jù)。關(guān)于PHP與JSON的操作可以查看本站收集的文章:。以下是server.php的詳細(xì)代碼,其中數(shù)據(jù)連接部分省略,請(qǐng)大家自行建立數(shù)據(jù)連接。

 

 
  1. include_once("connect.php"); //連接數(shù)據(jù)庫(kù)  
  2. $action=$_GET[action];  
  3. $id=intval($_GET[id]);  
  4. if($action=="getlink"){  
  5. $query=mysql_query("select * from user where id=$id");  
  6. $row=mysql_fetch_array($query);  
  7. $list=array("name"=>$row[username],"sex"=>$row[sex],"tel"=>$row[tel],"email"=>$row[email]);  
  8. echo json_encode($list);  
  9. }  

通過(guò)本文可以知道jQuery通過(guò)Ajax向服務(wù)端發(fā)送JSON請(qǐng)求,使用方法$.getJSON非常方便簡(jiǎn)單。并且可以將服務(wù)端返回的數(shù)據(jù)進(jìn)行解析,得到相應(yīng)字段的內(nèi)容,相比像HTML請(qǐng)求返回的一大串字符串那樣處理方便快捷。

最后附上mysql表結(jié)構(gòu)

 

 
  1. CREATE TABLE IF NOT EXISTS `user` (  
  2. `id` int(11) NOT NULL auto_increment,  
  3. `username` varchar(100) NOT NULL,  
  4. `sex` varchar(6) NOT NULL,  
  5. `tel` varchar(50) NOT NULL,  
  6. `email` varchar(64) NOT NULL,  
  7. PRIMARY KEY (`id`)  
  8. ) ENGINE=MyISAM DEFAULT CHARSET=utf8; 

以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 天气| 洛宁县| 栾川县| 普兰店市| 彭泽县| 夏河县| 禹州市| 红安县| 麻栗坡县| 岗巴县| 大新县| 抚远县| 石景山区| 工布江达县| 黎城县| 奉新县| 洞口县| 陇南市| 图们市| 石门县| 恩施市| 永嘉县| 吴桥县| 叶城县| 新邵县| 岫岩| 石柱| 宁国市| 建湖县| 舟曲县| 慈溪市| 沙雅县| 新沂市| 白玉县| 清原| 麟游县| 龙山县| 渑池县| 吉林省| 皋兰县| 如东县|