json的定义、标准格式及json字符串检验


Posted in Javascript onMay 11, 2014

现在越来越多的项目和开发插件等默认都会支持和使用json数据格式,作为数据保持、传输的一种方式。
说是其中一种,就标示还有好多其他格式。比如:最多是xml。webservice的标准数据格式。
不过由于json是JavaScript 对象表示法(JavaScript Object Notation),天生就对js支持很好,
所以现在很多的ajax等都使用json,反而会更好处理一些。

1、定义

什么是 JSON ?
1.JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation)
2.JSON 是轻量级的文本数据交换格式
3.JSON 独立于语言 *
4.JSON 具有自我描述性,更易理解
* JSON 使用 JavaScript 语法来描述数据对象,但是 JSON 仍然独立于语言和平台。JSON 解析器和 JSON 库支持许多不同的编程语言。
w3c的标准说明如下:
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。 这些特性使JSON成为理想的数据交换语言。

JSON建构于两种结构:

1.“名称/值”对的集合(A collection of name/value pairs)。不同的语言中,它被理解为对象(object),纪录(record),结构(struct),字典(dictionary),哈希表(hash table),有键列表(keyed list),或者关联数组 (associative array)。
2.值的有序列表(An ordered list of values)。在大部分语言中,它被理解为数组(array)。
这些都是常见的数据结构。事实上大部分现代计算机语言都以某种形式支持它们。这使得一种数据格式在同样基于这些结构的编程语言之间交换成为可能。

JSON具有以下这些形式:

对象是一个无序的“‘名称/值'对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值' 对”之间使用“,”(逗号)分隔。

json的定义、标准格式及json字符串检验

注意:如果后台直接传递对象来js,则是json格式的。参考文章:

[Jquery+asp.net 后台数据传到前台js进行解析的办法说明]
[jquery ajax传递对象(数组)到后台并解析的实现]

数组是值(value)的有序集合。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间使用“,”(逗号)分隔。

json的定义、标准格式及json字符串检验

注意:传递数据这个就好理解。其实就一个array。array和json直接的关系,请参考文章:

[javascript对象及数组 json的一些了解说明]

2、json标准:

json表示:我没有标准。哈哈。我说的标准是指什么样的格式化的字符串js才能解析成json?

下面这个json串就是正确的:

{
    "employees": [
        {
            "firstName": "Bill",
            "lastName": "Gates"
        },
        {
            "firstName": "George",
            "lastName": "Bush"
        },
        {
            "firstName": "Thomas",
            "lastName": "Carter"
        }
    ]
}

注意:

json串,在js中会解析成对象。其中对象的名称比如:
employees、firstName,必须用""或者''引起来才行。后面的value,如果是int和bool(js是不区分的哦),可以不用""或者''引起来,其他的字符串必须引起来,尤其是记得把时间日期引起来!

总结如下:

里面的是一个对象,如果是多个对象,则用逗号间隔,即{},{},这样就组成了一个对象序列,为了辨别开始和结束,则需要加上[]才能进行传递,则实际传递的形式应该是[{},{}],如果只要传递一个对象,则{}的形式就可以了。接下来就是对象属性的表现方式了,属性必须在""
里面,属性与值之间用:隔开,属性之间用,来分隔,如果属性的值为数组,则用[]包括起来,这样实际传递的数据格式可能有:1、{"属性1":值1,"属性2":值2},如果值为字符串,则也需要用""括起来(下同)。2、{"属性1":值1,"属性2":[值1,值2]},其中属性2是一个数组,包含
了值1和值2。3、{"属性1":值1,"属性2":{"属性a":值a,"属性b":[值b,值c]}},这个比较复杂了,属性2是个对象,这个对象由包含属性a和属性b,属性b又是一个数组包含值b和值c。我想这些应该是最基本了,其余的就是在此基础上的拓展而已。

实际中,要序列化对象,在.net中只要调用Newtonsoft.Json.JavaConvert.SerializeObject();函数即可

参考:

jquery ajax传递对象(数组)到后台并解析的实现 

https://3water.com/article/40131.htm

3、json有这么多要求(其实不多了),我们怎么判断其正确性?

有办法,就是你打印出来字符串,自己的按照上面的结构对应一下,或者直接使用在线检验工具检验。

参考:http://www.kjson.com/
http://tool.oschina.net/codeformat/json

Javascript 相关文章推荐
JS获取整个页面文档的实现代码
Dec 15 Javascript
幻灯片带网页设计中的20个奇妙应用示例小结
May 27 Javascript
css配合jquery美化 select
Nov 29 Javascript
理解javascript模块化
Mar 28 Javascript
Node.js的Koa框架上手及MySQL操作指南
Jun 13 Javascript
漂亮! js实现颜色渐变效果
Aug 12 Javascript
基于JavaScript实现自动更新倒计时效果
Dec 19 Javascript
Vue+jquery实现表格指定列的文字收缩的示例代码
Jan 09 jQuery
jquery.pager.js实现分页效果
Jul 29 jQuery
jQuery实现颜色打字机的完整代码
Mar 19 jQuery
jQuery实现B2B网站后台管理系统侧导航
Jul 08 jQuery
vue实现简易的双向数据绑定
Dec 29 Vue.js
Jquery操作js数组及对象示例代码
May 11 #Javascript
Jquery+asp.net后台数据传到前台js进行解析的方法
May 11 #Javascript
如何防止回车(enter)键提交表单
May 11 #Javascript
js取整数、取余数的方法
May 11 #Javascript
浏览器窗口大小变化时使用resize事件对框架不起作用的解决方法
May 11 #Javascript
基于jquery实现的图片在各种分辨率下未知的容器内上下左右居中
May 11 #Javascript
基于jQuery的判断iPad、iPhone、Android是横屏还是竖屏的代码
May 11 #Javascript
You might like
用PHP读注册表
2006/10/09 PHP
php新建文件自动编号的思路与实现
2011/06/27 PHP
第4章 数据处理-php正则表达式-郑阿奇(续)
2011/07/04 PHP
ThinkPHP3.2框架使用addAll()批量插入数据的方法
2017/03/16 PHP
thinkPHP5.0框架URL访问方法详解
2017/03/18 PHP
PHP7 整型处理机制修改
2021/03/09 PHP
设为首页加入收藏兼容360/火狐/谷歌/IE等主流浏览器的代码
2013/03/26 Javascript
javaScript的函数对象的声明详解
2015/02/06 Javascript
javascript实现textarea中tab键的缩排处理方法
2015/06/26 Javascript
浅谈JavaScript中的作用域和闭包问题
2015/07/07 Javascript
Javascript类型系统之undefined和null浅析
2016/07/13 Javascript
AngularJS 应用身份认证的技巧总结
2016/11/07 Javascript
Bootstrap基本样式学习笔记之图片(6)
2016/12/07 Javascript
任意Json转成无序列表的方法示例
2016/12/09 Javascript
详解Html a标签中href和onclick用法、区别、优先级别
2017/01/16 Javascript
JavaScript实现shuffle数组洗牌操作示例
2019/01/03 Javascript
jQuery内容过滤选择器与子元素过滤选择器用法实例分析
2019/02/20 jQuery
详解django模板与vue.js冲突问题
2019/07/07 Javascript
js实现查询商品案例
2020/07/22 Javascript
JS中队列和双端队列实现及应用详解
2020/09/29 Javascript
[01:31]完美与DOTA2历程
2014/07/31 DOTA
[02:11]2016国际邀请赛中国区预选赛全程回顾
2016/07/01 DOTA
python探索之BaseHTTPServer-实现Web服务器介绍
2017/10/28 Python
Python实现通讯录功能
2018/02/22 Python
python 二维数组90度旋转的方法
2019/01/28 Python
python 内置函数汇总详解
2019/09/16 Python
使用python接受tgam的脑波数据实例
2020/04/09 Python
英国家居用品和家居装饰品购物网站:Cox & Cox
2019/08/25 全球购物
航海技术专业毕业生求职信
2014/04/06 职场文书
作风建设剖析材料
2014/10/06 职场文书
文化苦旅读书笔记
2015/06/29 职场文书
党员干部学习十八届五中全会精神心得体会
2016/01/05 职场文书
纯CSS实现酷炫的霓虹灯效果
2021/04/13 HTML / CSS
python基础学习之递归函数知识总结
2021/05/26 Python
Spring Security使用单点登录的权限功能
2022/04/03 Java/Android
MySQL事务的隔离级别详情
2022/07/15 MySQL