JavaScript 如何处理 php 返回json格式的数据
JavaScript 如何处理 php 返回json格式的数据,下面我们通过一个示例来说明!
假设php返回如下一个数组:
查看代码打印
01
$arr = array(
02
array(
03
'name'=>'qianyuqianxun',
04
'nick'=>'千与千寻',
05
'contact'=>array(
06
'website'=>''
07
)
08
),
09
array(
10
'name'=>'qisha',
11
'nick'=>'七煞',
12
'email'=>'yhm.1234@163.com',
13
'contact'=>array(
14
'website'=>''
15
)
16
)
17
);
18
print_r(json_encode($arr));
19
exit;
则客户端JS可如下调用以上返回的数据:
查看代码打印
01
$(document).ready(function(){
02
var url='/json.php'
03
$('#submitBtn').click(function(){
04
$.post(url,'',function(msg){
05
var myObject=eval('('+msg+')');//msg为返回的类型为字符串,转化为json对象 06
var str='';
07
var len=myObject.length;
08
for(i=0;i<len;i++){
09
str+='<tr><td>'+myObject[i].name+'</td><td>'+myObject[i].nick+'</td><td>'+myObject[i].contact.website+'</td></tr>';
10
}
11
$('#feedbackTable').html(str);
12
})
13
})
14
})
第二篇:JavaScript操作Json
JSON (JavaScript Object Notation)一种简单的数据格式,比xml更轻巧。 JSON 是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON 数据不需要任何特殊的 API 或工具包。
JSON的规则很简单: 对象是一个无序的“‘名称/值’对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’ 对”之间使用“,”(逗号)分隔。具体细节参考
举个简单的例子:
js 代码 1.
2.
3.
4.
5.
6. 7.
8.
9. function showJSON() { var user = { "username":"andy", "age":20, "info": { "tel": "123456", "cellphone": "98765"}, "address": [ {"city":"beijing","postcode":"222333"},
10. {"city":"newyork","postcode":"555666"}
11. ]
12. }
13.
14. alert(user.username);
15. alert(user.age);
16. alert(user.info.cellphone);
17. alert(user.address[0].city);
18. alert(user.address[0].postcode);
19. }
这表示一个user对象,拥有username, age, info, address 等属性。 同样也可以用JSON来简单的修改数据,修改上面的例子
js 代码
1.
2. function showJSON() { var user =
3.
4.
5.
6.
7.
8.
9. { "username":"andy", "age":20, "info": { "tel": "123456", "cellphone": "98765"}, "address": [ {"city":"beijing","postcode":"222333"},
10. {"city":"newyork","postcode":"555666"}
11. ]
12. }
13.
14. alert(user.username);
15. alert(user.age);
16. alert(user.info.cellphone);
17. alert(user.address[0].city);
18. alert(user.address[0].postcode);
19.
20. user.username = "Tom";
21. alert(user.username);
22. }
JSON提供了json.js包,下载 后,将其引入然后就可以简单的使用object.toJSONString()转换成JSON数据。
js 代码
1.
2.
3.
4.
5.
6.
7.
8.
9. function showCar() { var carr = new Car("Dodge", "Coronet R/T", 1968, "yellow"); alert(carr.toJSONString()); } function Car(make, model, year, color) { this.make = make; this.model = model; this.year = year;
10. this.color = color;
11. }
可以使用eval来转换JSON字符到Object
js 代码 1.
2.
3.
4.
5. function myEval() { var str = '{ "name": "Violet", "occupation": "character" }'; var obj = eval('(' + str + ')'); alert(obj.toJSONString()); }
或者使用parseJSON()方法
js 代码 1.
2.
3.
4.
5. function myEval() { var str = '{ "name": "Violet", "occupation": "character" }'; var obj = str.parseJSON(); alert(obj.toJSONString()); }
下面使用prototype写一个JSON的ajax例子。
先写一个servlet (我的是servlet.ajax.JSONTest1.java)就写一句话 java 代码
1. response.getWriter().print("{ /"name/": /"Violet/", /"occupation/": /"character/" }");
再在页面中写一个ajax的请求
js 代码 1.
2.
3.
4.
5.
6.
7.
8.
9. function sendRequest() { var url = "/MyWebApp/JSONTest1"; var mailAjax = new Ajax.Request( url, { method: 'get', onComplete: jsonResponse } );
10. }
11.
12. function jsonResponse(originalRequest) {
13. alert(originalRequest.responseText);
14. var myobj = originalRequest.responseText.parseJSON();
15. alert(myobj.name);
16. }
prototype-1.5.1.js中提供了JSON的方法,String.evalJSON(), 可以不使用json.js, 修改上面的方法
js 代码
1.
2.
3.
4. 5. function jsonResponse(originalRequest) { alert(originalRequest.responseText); var myobj = originalRequest.responseText.evalJSON(true); alert(myobj.name); }
JSON还提供了java的jar包 API也很简单,下面举个例子
在javascript中填加请求参数
js 代码 1.
2.
3.
4.
5.
6.
7.
8.
9. function sendRequest() { var carr = new Car("Dodge", "Coronet R/T", 1968, "yellow"); var pars = "car=" + carr.toJSONString(); var url = "/MyWebApp/JSONTest1"; var mailAjax = new Ajax.Request( url, { method: 'get',
10. parameters: pars,
11. onComplete: jsonResponse
12. }
13. );
14. } 使用JSON请求字符串就可以简单的生成JSONObject并进行解析,修改servlet添加JSON的处理(要使用json.jar)
java 代码 1. private void doService(HttpServletRequest request, HttpServletR
esponse response) throws IOException {
String s3 = request.getParameter("car"); try {
JSONObject jsonObj = new JSONObject(s3);
System.out.println(jsonObj.getString("model"));
System.out.println(jsonObj.getInt("year"));
} catch (JSONException e) {
e.printStackTrace();
}
/": /"character/" }"); 2. 3. 4. 5. 6. 7. 8. 9. 10. response.getWriter().print("{ /"name/": /"Violet/", /"occupation
11. }
同样可以使用JSONObject生成JSON字符串,修改servlet
java 代码 1. private void doService(HttpServletRequest request, HttpServletResponse resp
onse) throws IOException {
2. String s3 = request.getParameter("car");
3. try {
4. JSONObject jsonObj = new JSONObject(s3);
5. System.out.println(jsonObj.getString("model"));
6. System.out.println(jsonObj.getInt("year"));
7. } catch (JSONException e) {
8. e.printStackTrace();
9. }
10.
11. JSONObject resultJSON = new JSONObject();
12. try {
13. resultJSON.append("name", "Violet") 14. .append("occupation", "developer")
15. .append("age", new Integer(22));
16. System.out.println(resultJSON.toString());
17. } catch (JSONException e) {
18. e.printStackTrace();
19. }
20. response.getWriter().print(resultJSON.toString());
21. }
js 代码
1. function jsonResponse(originalRequest) {
2. alert(originalRequest.responseText);
3. var myobj = originalRequest.responseText.evalJSON(true);
4. alert(myobj.name);
5. alert(myobj.age);
6. }