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 相关文章推荐
基于jQuery捕获超链接事件进行局部刷新代码
May 10 Javascript
浅谈bootstrap源码分析之tab(选项卡)
Jun 06 Javascript
Bootstrap前端开发案例二
Jun 17 Javascript
轻松掌握JavaScript状态模式
Sep 07 Javascript
Bootstrap Modal遮罩弹出层代码分享
Nov 21 Javascript
JavaScript对象封装的简单实现方法(3种方法)
Jan 03 Javascript
JavaScript Canvas绘制圆形时钟效果
Aug 20 Javascript
jQuery实现菜单栏导航效果
Aug 15 jQuery
详解如何制作并发布一个vue的组件的npm包
Nov 10 Javascript
JS正则表达式封装与使用操作示例
May 15 Javascript
微信小程序 数据缓存实现方法详解
Aug 26 Javascript
Vue.js实现大转盘抽奖总结及实现思路
Oct 09 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数据库操作面向对象的优点
2006/10/09 PHP
php imagecreatetruecolor 创建高清和透明图片代码小结
2010/05/15 PHP
PHP 实现类似js中alert() 提示框
2015/03/18 PHP
JavaScript中的私有/静态属性介绍
2012/07/26 Javascript
详细介绍jQuery.outerWidth() 函数具体用法
2015/07/20 Javascript
全面解析Bootstrap表单使用方法(表单控件)
2015/11/24 Javascript
jquery关于事件冒泡和事件委托的技巧及阻止与允许事件冒泡的三种实现方法
2015/11/27 Javascript
Extjs4.0 ComboBox如何实现三级联动
2016/05/11 Javascript
Javascript之Date对象详解
2016/06/07 Javascript
js css自定义分页效果
2017/02/24 Javascript
ionic 自定义弹框效果
2017/06/27 Javascript
利用JS制作万年历的方法
2017/08/16 Javascript
浅谈PDF.js使用心得
2018/06/07 Javascript
Vue递归组件+Vuex开发树形组件Tree--递归组件的简单实现
2019/04/01 Javascript
微信小程序如何自定义table组件
2019/06/29 Javascript
Vue 自定义指令实现一键 Copy功能
2019/09/16 Javascript
js实现GIF图片的分解和合成
2019/10/24 Javascript
原生JS与JQ获取元素的区别详解
2020/02/13 Javascript
javascript单张多张图无缝滚动实例代码
2020/05/10 Javascript
Python使用百度API上传文件到百度网盘代码分享
2014/11/08 Python
Python2.7环境Flask框架安装简明教程【已测试】
2018/07/13 Python
python排序函数sort()与sorted()的区别
2018/09/18 Python
Python基本数据结构与用法详解【列表、元组、集合、字典】
2019/03/23 Python
python getpass实现密文实例详解
2019/09/24 Python
Python图像处理库PIL中图像格式转换的实现
2020/02/26 Python
通俗讲解python 装饰器
2020/09/07 Python
python excel和yaml文件的读取封装
2021/01/12 Python
医务工作者先进事迹材料
2014/01/26 职场文书
商场客服专员岗位职责
2014/06/13 职场文书
人事专员岗位职责说明书
2014/07/30 职场文书
中华在我心中演讲稿
2014/09/13 职场文书
2014年银行员工工作总结
2014/11/12 职场文书
党员承诺书范文2015
2015/04/27 职场文书
新闻稿标题
2015/07/18 职场文书
2016年寒假生活小结
2015/10/10 职场文书
怎样做好公众演讲能力?
2019/08/28 职场文书