JSON

JavaScript如何处理解析JSON数据详解

字号+ 作者:H5之家 来源:H5之家 2015-10-04 17:21 我要评论( )

JSON也就是JavaScript Object Notation,是一个描述数据的轻量级语法。JSON的优雅是因为它是JavaScript语言的一个子集。接下来你将看到它为什么如此重要。首先,

JSON (JavaScript Object Notation)一种简单的数据格式,比xml更轻巧。 JSON 是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON 数据不需要任何特殊的 API 或工具包。

JSON的规则很简单: 对象是一个无序的“‘名称/值’对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’ 对”之间使用“,”(逗号)分隔。具体细节参考

举个简单的例子:

js 代码

function showJSON() {     var user =     {     "username":"andy",     "age":20,     "info": { "tel": "123456", "cellphone": "98765"},     "address":     [     {"city":"beijing","postcode":"222333"},     {"city":"newyork","postcode":"555666"}     ]     }     alert(user.username);     alert(user.age);     alert(user.info.cellphone);     alert(user.address[0].city);     alert(user.address[0].postcode);     }   

这表示一个user对象,拥有username, age, info, address 等属性。

同样也可以用JSON来简单的修改数据,修改上面的例子

js 代码

function showJSON() {     var user =     {     "username":"andy",     "age":20,     "info": { "tel": "123456", "cellphone": "98765"},     "address":     [     {"city":"beijing","postcode":"222333"},     {"city":"newyork","postcode":"555666"}     ]     }     alert(user.username);     alert(user.age);     alert(user.info.cellphone);     alert(user.address[0].city);     alert(user.address[0].postcode);     user.username = "Tom";     alert(user.username);     }  

JSON提供了json.js包,下载 后,将其引入然后就可以简单的使用object.toJSONString()转换成JSON数据。

js 代码

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;     this.color   =   color;     } 

可以使用eval来转换JSON字符到Object

js 代码

function myEval() {     var str = '{ "name": "Violet", "occupation": "character" }';     var obj = eval('(' + str + ')');     alert(obj.toJSONString());     }    

或者使用parseJSON()方法

js 代码

function myEval() {     var str = '{ "name": "Violet", "occupation": "character" }';     var obj = str.parseJSON();     alert(obj.toJSONString());     }  

下面使用prototype写一个JSON的ajax例子。

先写一个servlet (我的是servlet.ajax.JSONTest1.java)就写一句话 

java 代码

response.getWriter().print("{ \"name\": \"Violet\", \"occupation\": \"character\" }");   

再在页面中写一个ajax的请求

js 代码

function sendRequest() {     var url = "/MyWebApp/JSONTest1";     var mailAjax = new Ajax.Request(     url,     {     method: 'get',     onComplete: jsonResponse     }     );     }     function jsonResponse(originalRequest) {     alert(originalRequest.responseText);     var myobj = originalRequest.responseText.parseJSON();     alert(myobj.name);     } 

prototype-1.5.1.js中提供了JSON的方法,String.evalJSON(), 可以不使用json.js, 修改上面的方法

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • php CI 实战教程:[5]用curl获取json并解析

    php CI 实战教程:[5]用curl获取json并解析

    2016-02-26 17:00

  •  JSON入门级学习总结-JSON数据结构

    JSON入门级学习总结-JSON数据结构

    2016-02-25 11:05

  • Android解析Json速度最快的库:json

    Android解析Json速度最快的库:json

    2016-02-13 18:00

  • JavaScript转换与解析JSON方法实例详解第1/2页

    JavaScript转换与解析JSON方法实例详解第1/2页

    2016-02-10 21:25

网友点评
p