博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
json数据类型
阅读量:7296 次
发布时间:2019-06-30

本文共 1598 字,大约阅读时间需要 5 分钟。

JSON 语法规则

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

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

JSON 名称/值对

JSON 数据的书写格式是:名称/值对。

名称/值对包括字段名称(在双引号中),后面写一个冒号,然后是值:

"firstName" : "John"

这很容易理解,等价于这条 JavaScript 语句:

firstName = "John"

JSON 值

JSON 值可以是:

  • 数字(整数或浮点数)
  • 字符串(在双引号中)
  • 逻辑值(true 或 false)
  • 数组(在方括号中)
  • 对象(在花括号中)
  • null

JSON 对象

JSON 对象在花括号中书写:

对象可以包含多个名称/值对:

{ "firstName":"John" , "lastName":"Doe" }

这一点也容易理解,与这条 JavaScript 语句等价:

firstName = "John"lastName = "Doe"

JSON 数组

JSON 数组在方括号中书写:

数组可包含多个对象:

{"employees": [{ "firstName":"John" , "lastName":"Doe" },{ "firstName":"Anna" , "lastName":"Smith" },{ "firstName":"Peter" , "lastName":"Jones" }]}

在上面的例子中,对象 "employees" 是包含三个对象的数组。每个对象代表一条关于某人(有姓和名)的记录。

JSON 使用 JavaScript 语法

因为 JSON 使用 JavaScript 语法,所以无需额外的软件就能处理 JavaScript 中的 JSON。

通过 JavaScript,您可以创建一个对象数组,并像这样进行赋值:

例子

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

可以像这样访问 JavaScript 对象数组中的第一项:

employees[0].lastName;

返回的内容是:

Gates

可以像这样修改数据:

employees[0].lastName = "Jobs";

JSON 实例 - 来自字符串的对象

创建包含 JSON 语法的 JavaScript 字符串:

var txt = '{ "employees" : [' +'{ "firstName":"Bill" , "lastName":"Gates" },' +'{ "firstName":"George" , "lastName":"Bush" },' +'{ "firstName":"Thomas" , "lastName":"Carter" } ]}';

由于 JSON 语法是 JavaScript 语法的子集,JavaScript 函数 eval() 可用于将 JSON 文本转换为 JavaScript 对象。

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

var obj = eval ("(" + txt + ")");

在网页中使用 JavaScript 对象:

例子

First Name:

Last Name:

转载于:https://www.cnblogs.com/bilibiliganbei/p/6037712.html

你可能感兴趣的文章
HTML5高性能拓扑图 - 十万图元渲染
查看>>
C语言指针学习【2】
查看>>
伸展树的学习(七):伸展树常用的操作合集
查看>>
Hyper-V 3 虚拟机快照之五 快照应用中发现的问题
查看>>
java 使用tomcat的JNDI数据源
查看>>
css代码优化(总结)
查看>>
Linux下jdk安装和环境变量配置
查看>>
创建了我自己的第一个rails应用
查看>>
Flex 子界面调用父界面的方法
查看>>
Linux命令:MySQL系列之八--MySQL事务相关内容
查看>>
HTTP 错误 404.3 - Not Found 由于扩展配置问题而无法提供您请求的页面。
查看>>
ELK+Filebeat+Nginx集中式日志解决方案(三)—— 添加kafka+zookeeper集群
查看>>
动态加载动态库(C#)反射
查看>>
iOS UI-利用可视化(StoryBoard)在Scroll View的内容中添加一个TableView和一个ColletionView...
查看>>
为了学好linux 特此写下决心书!
查看>>
使用SpringMVC拦截器做一个简单的权限控制
查看>>
Android学习——Animation动画效果
查看>>
BI实时图表实现数据可视化的原理
查看>>
OpenGG.Clean.Player{喜歡看視頻用戶強推}
查看>>
不能在此路径中使用此配置节。如果在父级别上锁定了该节,便会出现这种情况。...
查看>>