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前端框架关于重构的失败经验分享
Mar 17 Javascript
js添加事件的通用方法推荐
May 15 Javascript
教你如何在Node.js中使用jQuery
Aug 28 Javascript
js实现随机抽选效果、随机抽选红色球效果
Jan 13 Javascript
JavaScript解析JSON格式数据的方法示例
Jan 24 Javascript
js实现字符全排列算法的简单方法
May 01 Javascript
详解vue mint-ui源码解析之loadmore组件
Oct 11 Javascript
浅谈vue自定义全局组件并通过全局方法 Vue.use() 使用该组件
Dec 07 Javascript
bootstrap fileinput插件实现预览上传照片功能
Jan 23 Javascript
vue+elementUI 复杂表单的验证、数据提交方案问题
Jun 24 Javascript
Vue2.4+新增属性.sync、$attrs、$listeners的具体使用
Mar 08 Javascript
一行JavaScript代码如何实现瀑布流布局
Dec 11 Javascript
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.ini中文版(2)
2006/10/09 PHP
非常好的php目录导航文件代码
2006/10/09 PHP
Discuz!X中SESSION机制实例详解
2015/09/23 PHP
Javascript this关键字使用分析
2008/10/21 Javascript
Mootools 1.2教程 函数
2009/09/15 Javascript
Span元素的width属性无效果原因及解决方案
2010/01/15 Javascript
菜鸟学习JavaScript小实验之函数引用
2010/11/17 Javascript
jQuery实现仿淘宝带有指示条的图片转动切换效果完整实例
2015/03/04 Javascript
基于JavaScript实现图片点击弹出窗口而不是保存
2016/02/06 Javascript
解析Node.js基于模块和包的代码部署方式
2016/02/16 Javascript
详解Matlab中 sort 函数用法
2016/03/20 Javascript
jQuery插件easyUI实现通过JS显示Dialog的方法
2016/09/16 Javascript
Vue常用指令V-model用法
2017/03/08 Javascript
不使用JavaScript实现菜单的打开和关闭效果demo
2018/05/01 Javascript
微信小程序模拟cookie的实现
2018/06/20 Javascript
详解angular2 控制视图的封装模式
2018/12/27 Javascript
JavaScript递归函数定义与用法实例分析
2019/01/24 Javascript
vue脚手架项目创建步骤详解
2021/03/02 Vue.js
Python multiprocessing.Manager介绍和实例(进程间共享数据)
2014/11/21 Python
python妹子图简单爬虫实例
2015/07/07 Python
python实现在字符串中查找子字符串的方法
2015/07/11 Python
详解python中的文件与目录操作
2017/07/11 Python
对django xadmin自定义菜单的实例详解
2019/01/03 Python
Django文件存储 自己定制存储系统解析
2019/08/02 Python
Django之form组件自动校验数据实现
2020/01/14 Python
python右对齐的实例方法
2020/07/05 Python
python温度转换华氏温度实现代码
2020/12/06 Python
Selenium+BeautifulSoup+json获取Script标签内的json数据
2020/12/07 Python
举例讲解Python装饰器
2020/12/24 Python
CSS3制作3D立方体loading特效
2020/11/09 HTML / CSS
Html5 页面适配iPhoneX(就是那么简单)
2019/09/05 HTML / CSS
应用电子技术专业个人求职信
2013/09/21 职场文书
教师研修随笔感言
2015/11/18 职场文书
技术入股合作协议书
2016/03/21 职场文书
《时代广场的蟋蟀》读后感:真挚友情,温暖世界!
2020/01/08 职场文书
MySQL 数据恢复的多种方法汇总
2021/06/21 MySQL