-

JS遍历Json字符串

1、将Json字符串转换成JSON对象

var t='{"firstName": "cyra", "lastName": "richardson"}'; 
var obj = eval('(' + t + ')');

2、遍历读取键值对

for(var str in obj){ 
alert(str+'='+obj[str]); 
}


代码示例:

  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
  2. <HTML>
  3. <HEAD>
  4. <TITLE> New Document </TITLE>
  5. <SCRIPT LANGUAGE="JavaScript">
  6. var t="{'firstName': 'cyra', 'lastName': 'richardson', 'address': { 'streetAddress': '1 Microsoft way', 'city': 'Redmond', 'state': 'WA', 'postalCode': 98052 },'phoneNumbers': [ '425-777-7777','206-777-7777' ] }";
  7. var jsonobj=eval('('+t+')');//单个JSON对象时要加括号,JSON数组就不需要了
  8. alert(jsonobj.firstName);
  9. alert(jsonobj.lastName);
  10. var t2="[{name:'zhangsan',age:'24'},{name:'lisi',age:'30'},{name:'wangwu',age:'16'},{name:'tianqi',age:'7'}] ";
  11. var myobj=eval(t2);
  12. for(var i=0;i<myobj.length;i++){
  13. alert(myobj[i].name);
  14. alert(myobj[i].age);
  15. }
  16. var t3="[['<a href=# onclick=openLink(14113295100,社旗县国税局桥头税务所,14113295100,d6d223892dc94f5bb501d4408a68333d,swjg_dm);>14113295100</a>','社旗县国税局桥头税务所','社旗县城郊乡长江路西段']]";
  17. //通过eval() 函数可以将JSON字符串转化为对象
  18. var obj = eval(t3);
  19. for(var i=0;i<obj.length;i++){
  20. for(var j=0;j<obj[i].length;j++){
  21. alert(obj[i][j]);
  22. }
  23. }
  24. /*
  25. stringifier 函数的作用跟 parse 相反, 用来将一个js对象转换为 JSON 文本。
  26. var jsonText = JSON.stringify(obj);
  27. alert(jsonText);
  28. //如果基于安全的考虑的话,最好是使用一个 JSON 解析器。 一个 JSON 解析器将只接受 JSON 文本。所以是更安全的。
  29. var myObject = JSON.parse(myJSONtext, filter);
  30. //可选的 filter 参数将遍历每一个value key 值对, 并进行相关的处理。如:
  31. //如
  32. myData = JSON.parse(text, function (key, value) {
  33. return key.indexOf('date') >= 0 ? new Date(value) : value; });
  34. //stringifier 函数的作用跟 parse 相反, 用来将一个js对象转换为 JSON 文本。
  35. var myJSONText = JSON.stringifier(myObject);
  36. */
  37. </SCRIPT>
  38. </HEAD>
  39. <BODY>
  40. </BODY>
  41. </HTML>


附加JSP后台拼JSON字符串

  1. <%@ page contentType="text/html;charset=GBK" %>
  2. <%@ taglib uri="/tags/web-flex" prefix="flex"%>
  3. <%@ taglib uri="/tags/web-grid" prefix="grid"%>
  4. <%@ taglib uri="/tags/web-html" prefix="html"%>
  5. <%@ taglib uri="/tags/web-sotower" prefix="sotower"%>
  6. <%@ taglib uri="/tags/sotower-bsp" prefix="bsp"%>
  7. <%@page import="java.util.List"%>
  8. <%@page import="com.wuynw.ygxx.po.WyYuang"%>
  9. <%
  10. List reslist=(List)request.getAttribute("flexgrid.data");
  11. StringBuilder sb=new StringBuilder();
  12. sb.append("[");
  13. for(int i=0;i<reslist.size();i++)
  14. {
  15. WyYuang w=(WyYuang)reslist.get(i);
  16. if(i>0)
  17. {
  18. sb.append(",");
  19. }
  20. sb.append("{").append("\"").append("id").append("\"").append(":");
  21. sb.append("\"").append(w.getId()).append("\"").append(",");
  22. sb.append("\"").append("name").append("\"").append(":");
  23. sb.append("\"").append(w.getXingm()).append("\"").append(",");
  24. sb.append("\"").append("gongh").append("\"").append(":");
  25. sb.append("\"").append(w.getGongh()).append("\"").append(",");
  26. sb.append("\"").append("zhiw").append("\"").append(":");
  27. sb.append("\"").append(w.getZhiw()).append("\"").append(",");
  28. sb.append("\"").append("ruzrq").append("\"").append(":");
  29. sb.append("\"").append(w.getRuzrq()).append("\"").append("}");
  30. }
  31. sb.append("]");
  32. out.print(sb.toString());
  33. %>