JSON定义及应用

Wesley13
• 阅读 759

JSON定义及应用

1 什么是JSON?

  • JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation)

  • 是轻量级的文本数据交换格式,JSON 比 XML 更小、更快,更易解析。

2 JSON 语法规则

JSON 语法是 JavaScript 对象表示语法的子集。

  • 数据在名称/值对中
  • 数据由逗号分隔
  • 大括号保存对象
  • 中括号保存数组

JSON 值可以是:字符串, 数字, 对象, 数组, 布尔值 或 null

JavaScript 的值可以是:JSON 数据类型,也可以是 JavaScript 的表达式,包括函数,日期,及 undefined

3 JSON和JavaScript对象之间的转换

(1)JSON.parse()

需求:JSON 通常用于与服务端交换数据,在接收服务器数据时一般是字符串

作用:将json格式的字符串转换为JavaScript对象

语法:  JSON.parse(text[, reviver]) 

参数说明:

  • text:必需, 一个有效的 JSON 字符串。
  • reviver: 可选,一个转换结果的函数, 将为对象的每个成员调用此函数。

返回值:对象或数组

示例一:

var jsonStr = '{ "name":"runoob", "alexa":10000, "site":"www.runoob.com" }';    // json格式的字符串
var obj = JSON.parse(jsonStr);    // JavaScript对象
document.write("name = " + obj.name);
document.write("name = " + obj[name]);    // 第二种写法

示例二:

1 var text = '{ "name":"Runoob", "initDate":"2013-12-14", "site":"www.runoob.com"}';
2 var obj = JSON.parse(text, function (key, value) { // 函数会遍历字符串中所有key和value,得到返回的value
3     if (key == "initDate") {
4         return new Date(value);
5     } else {
6         return value;
7 }});
8 document.write("创建日期:" + obj.initDate);    // 输出,创建日期:Sat Dec 14 2013 08:00:00 GMT+0800 (中国标准时间)

(2)JSON.stringify()

需求:JSON 通常用于与服务端交换数据,在向服务器发送数据时一般是字符串

作用:将JavaScript对象转换为json格式的字符串

语法:  JSON.stringify(value[, replacer[, space]]) 

参数说明:

  • text:必需, JavaScript对象或数组。

  • replacer: 可选。用于转换结果的函数或数组。

    如果 replacer 是函数,则 JSON.stringify 将调用该函数,并传入每个成员的键和值。使用返回值而不是原始值。如果此函数返回 undefined,则排除成员。根对象的键是一个空字符串:""。

    如果 replacer 是数组,则仅转换该数组中具有键值的成员。成员的转换顺序与键在数组中的顺序一样。当 value 参数也为数组时,将忽略 replacer 数组。(意思就是,对象或数组中key值如果在数组中存在,才保留。不存在的就去掉)

  • space: 可选,文本添加缩进、空格和换行符,如果 space 是一个数字,则返回值文本在每个级别缩进指定数目的空格,如果 space 大于 10,则文本缩进 10 个空格。space 也可以使用非数字,如:\t。

返回值:json格式的字符串

示例一:

var obj = { "name":"runoob", "initDate":new Date(), "alexa":10000};
var jsonStr= JSON.stringify(obj);
document.write(jsonStr);    // 输出,{"name":"runoob","initDate":"2019-04-04T08:56:59.679Z","alexa":10000}

实例二:

 1 函数
 2 
 3 var obj = { "name":"Runoob", "age":23, "site":"www.runoob.com"};
 4 var jsonStr = JSON.stringify(obj, function(key,value){
 5     if (key == "age") {
 6         return 55;
 7     }
 8         return value;
 9 }, '\t');
10 document.write(jsonStr);    // 输出,{"name":"Runoob","age":55,"site":"www.runoob.com"}
11 
12 数组
13 
14 var obj = { "name":"Runoob", "age":23, "site":"www.runoob.com"};
15 var jsonStr = JSON.stringify(obj, [site,name], '\t');    // 保留数组中出现的对象的key值,按数组的顺序
16 document.write(jsonStr);    // 输出,{"site":"www.runoob.com","name":"Runoob"}

(3)eval()

作用:使用的是 JavaScript 编译器,可解析 JSON 文本,然后生成 JavaScript 对象。必须把文本包围在括号中,这样才能避免语法错误

语法: var obj = eval ("(" + txt + ")"); 

参数说明:

  • string:必需, 可以表示要计算的 JavaScript 表达式或要执行的语句。

返回值:返回计算string的值,如果有的话 (没有则不做任何改变返回)

 示例一:

// 表达式
eval("x=10;y=20;document.write(x*y)");  //output为200
document.write(eval("2+2"));  //output为4
var x=10;
document.write(eval(x+17));  //output为27

// json格式字符串
7 var json = '{"name":"GDT","age":23,"University":"GDUT"}';
8 var info = eval('(' + json + ')');  //解析为JSON对象
9 document.write(info);            //output为[object Object]

3.1 为什么eval()要用一对圆括号将字符串包起来?

  • 原因:归结于eval本身的问题,由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。

  • 解决方法:加上圆括号的目的是迫使eval函数在处理JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行。举一个例子,例如对象字面量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始和结束标记,那么{}将会被认为是执行了一句空语句。请看下列例子的不同

    alert(eval("{}")); // return undefined alert(eval('('+'{}'+')')); // return object[Object]

另外,相对于写法格式严格的JSON.parse()来说,eval()可以解析任何字符串,eval是不安全的,因为eval比较宽松,会有潜在的安全性问题。比如以下代码:

var str1 = '{"a":"b"}';
document.write(eval("("+str1+")"));   //正常解析为对象
var str2 = '{"a": (function(){alert("I can do something bad!");})()}';
eval('('+str2+')');                   //可以用来执行木马脚本

总结:第一次写自己的技术博文,很多都是从其他地方借鉴的。毕竟是第一次写,有不对的地方也请见谅,也暴露了我自己的逻辑思维需要提升了,讲述一个问题的解答方法比理解一个问题更难,希望以后能靠自己就写出好的博文,坚持就是胜利。

  加油 2019!

 【参考】

  1. https://www.cnblogs.com/DTBelieve/p/5346603.html JSON.parse()、JSON.stringify()、eval()讲解
  2. http://www.runoob.com/json/json-tutorial.html JSON教程
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
3年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
美凌格栋栋酱 美凌格栋栋酱
6小时前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(