摘要:本文實(shí)例講述了jQuery基于ajax操作json數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:jQuery Ajax 實(shí)例演示jQuery Ajax 的三種格式,在與后臺(tái)進(jìn)行數(shù)據(jù)交互的時(shí)候可以是json格式也可以是xml格式,本人建議將數(shù)據(jù)轉(zhuǎn)化成json格式。Xml與json的比較1、可讀性JSON和XML的可讀性可謂不相上下,一邊是建議的語(yǔ)法,一邊是規(guī)范的標(biāo)簽形式,很難分出勝負(fù)。2、可擴(kuò)展性XM
本文實(shí)例講述了jQuery基于ajax操作json數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
jQuery Ajax 實(shí)例演示
jQuery Ajax 的三種格式,在與后臺(tái)進(jìn)行數(shù)據(jù)交互的時(shí)候可以是json格式也可以是xml格式,本人建議將數(shù)據(jù)轉(zhuǎn)化成json格式。
Xml與json的比較
1、可讀性
JSON和XML的可讀性可謂不相上下,一邊是建議的語(yǔ)法,一邊是規(guī)范的標(biāo)簽形式,很難分出勝負(fù)。
2、可擴(kuò)展性
XML天生有很好的擴(kuò)展性,JSON當(dāng)然也有,沒(méi)有什么是XML能擴(kuò)展,JSON不能的。
3、編碼難度
XML有豐富的編碼工具,比如Dom4j、JDom等,JSON也有json.org提供的工具,但是JSON的編碼明顯比XML容易許多,即使不借助工 具也能寫(xiě)出JSON的代碼,可是要寫(xiě)好XML就不太容易了。
4、解碼難度
XML的解析得考慮子節(jié)點(diǎn)父節(jié)點(diǎn),讓人頭昏眼花,而JSON的解析難度幾乎為0。這一點(diǎn)XML輸?shù)恼媸菦](méi)話說(shuō)。
<html> <head> <title>jQuery Ajax 實(shí)例演示</title> </head> <script language="javascript" src="../lib/jquery.js"></script> <script language="javascript"> $(document).ready(function () { $('#send_ajax').click(function (){ var params=$('input').serialize(); //序列化表單的值 $.ajax({ url:'ajax_json.php', //后臺(tái)處理程序 type:'post', //數(shù)據(jù)發(fā)送方式 dataType:'json', //接受數(shù)據(jù)格式 data:params, //要傳遞的數(shù)據(jù) success:UPDATE_page //回傳函數(shù)(這里是函數(shù)名) }); }); //$.post()方式: $('#test_post').click(function (){ $.post( 'ajax_json.php', { username:$('#input1').val(), age:$('#input2').val(), sex:$('#input3').val(), job:$('#input4').val() }, function (data) //回傳函數(shù) { var myjson=''; eval('myjson=' + data + ';'); $('#result').html("姓名:" + myjson.username + "<br/>工作:" + myjson['job']); } ); }); //$.get()方式: $('#test_get').click(function () 'ajax_json.php', { username:$("#input1").val(), age:$("#input2").val(), sex:$("#input3").val(), job:$("#input4").val() }, function(data) //回傳函數(shù) { var myjson=''; eval("myjson=" + data + ";"); $("#result").html(myjson.job); } ); }); }); function UPDATE_page (json) //回傳函數(shù)實(shí)體,參數(shù)為XMLhttpRequest.responseText { var str="姓名:"+json.username+"<br />"; str+="年齡:"+json.age+"<br />"; str+="性別:"+json.sex+"<br />"; str+="工作:"+json.job+"<br />"; str+="追加測(cè)試:"+json.append; $("#result").html(str); } </script> <body> <div id="result" style="background:orange;border:1px solid red;width:300px;height:200px;"></div> <form id="formtest" action="" method="post"> <p><span>輸入姓名:</span><input type="text" name="username" id="input1" /></p> <p><span>輸入年齡:</span><input type="text" name="age" id="input2" /></p> <p><span>輸入性別:</span><input type="text" name="sex" id="input3" /></p> <p><span>輸入工作:</span><input type="text" name="job" id="input4" /></p> </form> <button id="send_ajax">提交</button> <button id="test_post">POST提交</button> <button id="test_get">GET提交</button> </body> </html>
PHP 文件 ajax_json.php:
<?php //$arr = $_POST; //若以$.get()方式發(fā)送數(shù)據(jù),則要改成$_GET.或者干脆:$_REQUEST $arr = $_REQUEST; $arr['append'] = '測(cè)試字符串'; //print_r($arr); $myjson = my_json_encode($arr); echo $myjson; function my_json_encode($phparr) { if(function_exists("json_encode")) { return json_encode($phparr); } else { require_once 'json/json.class.php'; $json = new Services_JSON; return $json->encode($phparr); } } ?>
更多關(guān)于jQuery基于ajax操作json數(shù)據(jù)簡(jiǎn)單示例請(qǐng)關(guān)注PHP中文網(wǎng)(ipnx.cn)其他文章!