解析

  1、定义:是指将符合 JSON 语法规则的字符串转换成对象的过程。

  2、不同的编程语言都提供了解析 JSON 字符串的方法,在这里主要讲解 JavaScript 中的解析方法。主要有三种:

  1)- 使用 eval()

  2)- 使用 JSON.parse()

  3)- 使用第三方库,例如 JQuery 等

  eval()

  1、eval() 函数的参数是一个字符串,其作用是直接执行其中的 JavaScript 代码。

  2、eval() 能够解析 JSON 字符串。从这里也可以看得出,JSON 和 JavaScript 是高度嵌合的。

  3、但是,现在已经很少直接使用 eval() 来解析了,如果您的浏览器版本真的是很旧,可能才需要这个方法。此外,eval() 是一个相对危险的函数,因为字符串中可能含有未知因素。在这里,作为学习,还是要知道这也是一种方法。

  4、请注意 eval() 的参数,在字符串两旁加了括号,这是必须的,否则会报错。

  5、因为 JSON 字符串是被大括号(“{}”)包围的,直接放到 eval() 会被当成语句块来执行,因此要在两旁加上括号,使其变成表达式。

  示例代码

<script>

var str = “console.log(‘hello’)”;

eval(sre);

</script>

  控制台输出的执行结果:

  示例代码

<script>

var str = ‘{ “name” : “Geoff Lui”,“age”  : 26}’;   //符合JSON语法规则的字符串

eval (“(“+str+”)”);

console.log(obj);

</script>

  执行结果:

  JSON.parse()

  1、现在绝大多数浏览器都以支持 JSON.parse(),是推荐使用的方式

示例代码:

<script>

var str = ‘{ “name” : “Geoff Lui”,“age”  : 26}’;   //符合JSON语法规则的字符串

var obj = JSON.parse(str);

console.log(obj);

</script>

  执行结果:

  2、如果输入了不符合规范的字符串,会报错

  3、JSON.parse() 可以有第二个参数,是一个函数。此函数有两个参数:name 和 value,分别代表名称和值。当传入一个 JSON 字符串后,JSON 的每一组名称/值对都要调用此函数。该函数有返回值,返回值将赋值给当前的名称(name)。

  示例代码:

<script>

var str = ‘{ “name” : “Geoff Lui”,“age”  : 26}’;   //符合JSON语法规则的字符串

var obj = JSON.parse(str,fun);

function fun (name , value){

console.log(name + “: ” + value);

return value;

}

console.log(obj);

</script>

执行结果:

示例代码:

<script>

var str = ‘{ “name” : “Geoff Lui”,“age”  : 26}’;   //符合JSON语法规则的字符串

var obj = JSON.parse(str,fun);

function fun (name , value){

if(name == “age” )

value = 14;

return value;

}

console.log(obj);

</script>

执行结果:

4、利用第二个参数,可以在解析 JSON 字符串的同时对数据进行一些处理。

原文链接:http://www.maiziedu.com/wiki/json/conversion/

最新文章

  1. C#操作剪贴板
  2. GitLab常见使用方法
  3. 将XML解析成DOM文档
  4. poj3667 Hotel
  5. .NET去掉HTML标记
  6. Android实现XML解析技术
  7. easyui的datagrid和panel如何让标题动态改变?
  8. 老李分享:QTP的录制原理以及实现
  9. Activity的生命之路
  10. Linux命令大全汇总,让你工作更有效率!
  11. 2018上C语言程序设计(高级)- 第1次作业成绩
  12. 将TUM数据集的RGB-D数据集转化为klg格式
  13. SQL Server 深入解析索引存储(非聚集索引)
  14. js中实现隐藏部分姓名或者电话号码
  15. luogu1712 区间 (尺取法+线段树)
  16. git core.autocrlf配置 解决Windows和Linux(Mac)换行问题
  17. 响应式布局与bootstrap框架
  18. lamp 相关
  19. MySQL: Connection Character Sets and Collations
  20. SeekBar的用法和自定义滑块的样式

热门文章

  1. C#中的字符串处理——找出最长数字子串
  2. php基础复习(一)smarty模板
  3. 2015年江西理工大学C语言程序设计竞赛(初级组)
  4. Easyui部分组件讲解
  5. CSS3那些不为人知的高级属性
  6. iOS- 详解文本属性Attributes
  7. List&lt;T&gt;
  8. unicode下char*和CString和一些数据之间的转换
  9. 取出ip address control的ip字符
  10. UI事件 计算器界面