JavaScript处理解析JSON数据过程详解

前端技术 2023/09/09 JavaScript

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

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

举个简单的例子:

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包,下载http://www.json.org/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, 修改上面的方法

js 代码

function jsonResponse(originalRequest) {  
  alert(originalRequest.responseText);  
  var myobj = originalRequest.responseText.evalJSON(true);  
  alert(myobj.name);  
  }  

JSON还提供了java的jar包 http://www.json.org/java/index.html API也很简单,下面举个例子

在javascript中填加请求参数

js 代码

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\',  
  parameters: pars,  
  onComplete: jsonResponse  
  }  
  );  
  }  

使用JSON请求字符串就可以简单的生成JSONObject并进行解析,修改servlet添加JSON的处理(要使用json.jar)

java 代码

private void doService(HttpServletRequest request, HttpServletResponse 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();  
  }  
  response.getWriter().print(\"{ \\\"name\\\": \\\"Violet\\\", \\\"occupation\\\": \\\"character\\\" }\");  
  }  

同样可以使用JSONObject生成JSON字符串,修改servlet

java 代码

private void doService(HttpServletRequest request, HttpServletResponse 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();  
  }  
  JSONObject resultJSON = new JSONObject();  
  try {  
  resultJSON.append(\"name\", \"Violet\")  
  .append(\"occupation\", \"developer\")  
  .append(\"age\", new Integer(22));  
  System.out.println(resultJSON.toString());  
  } catch (JSONException e) {  
  e.printStackTrace();  
  }  
  response.getWriter().print(resultJSON.toString());  
  }  
  js 代码
  function jsonResponse(originalRequest) {  
  alert(originalRequest.responseText);  
  var myobj = originalRequest.responseText.evalJSON(true);  
  alert(myobj.name);  
  alert(myobj.age);  
  } 

以上内容就是给大家介绍JavaScrip处理t解析JSON数据过程详解,希望对大家有所帮助。

本文地址:https://www.stayed.cn/item/25474

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。