2、JSON 语法

本文介绍JSON的基本语法,包括数据在名称/值对中表示、数组和对象的使用、布尔值和null值的概念,以及如何使用JavaScript处理JSON数据。

JSON 语法规则

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

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

JSON 名称/值对

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

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

"name" : "菜鸟教程"

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

name = "菜鸟教程"

JSON 值

JSON 值可以是:

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

JSON 数字

JSON 数字可以是整型或者浮点型:

{ "age":30 }

JSON 对象

JSON 对象在大括号({})中书写:

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

{ "name":"菜鸟教程" , "url":"www.runoob.com" }

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

name = "菜鸟教程"
url = "www.runoob.com"

JSON 数组

JSON 数组在中括号中书写:

数组可包含多个对象:

{
"sites": [
{ "name":"菜鸟教程" , "url":"www.runoob.com" }, 
{ "name":"google" , "url":"www.google.com" }, 
{ "name":"微博" , "url":"www.weibo.com" }
]
}

在上面的例子中,对象 "sites" 是包含三个对象的数组。每个对象代表一条关于某个网站(name、url)的记录。

JSON 布尔值

JSON 布尔值可以是 true 或者 false:

{ "flag":true }

JSON null

JSON 可以设置 null 值:

{ "runoob":null }

JSON 使用 JavaScript 语法

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

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

var sites = [
    { "name":"runoob" , "url":"www.runoob.com" }, 
    { "name":"google" , "url":"www.google.com" }, 
    { "name":"微博" , "url":"www.weibo.com" }
];

可以像这样访问 JavaScript 对象数组中的第一项(索引从 0 开始):

sites[0].name;

返回的内容是:

runoob

可以像这样修改数据:

sites[0].name="菜鸟教程";

在下面的章节,您将学到如何把 JSON 文本转换为 JavaScript 对象。

JSON 文件

  • JSON 文件的文件类型是 ".json"
  • JSON 文本的 MIME 类型是 "application/json"
### JSON 语法规范完整规则 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。以下是 JSON 的完整语法规范: #### 1. 数据结构 JSON 的数据结构由两种基本结构组成: - **对象**:无序的键值对集合,键必须是字符串,值可以是任何合法的 JSON 数据类型[^1]。 - **数组**:有序的值集合。 #### 2. 值的类型 JSON 支持以下七种数据类型[^3]: - **字符串**:用双引号括起来的文本。例如:`"Hello, World!"` - **数值**:整数或浮点数。例如:`42` 或 `3.14` - **对象**:键值对的集合,用大括号表示。例如: ```json { "name": "Alice", "age": 25 } ``` - **数组**:一组有序的值,用方括号表示。例如: ```json [1, 2, 3, "apple", "banana"] ``` - **布尔值**:`true` 或 `false` - **null**:空值 - **其他类型**:不支持 `undefined`、函数等类型。 #### 3. 键名 键名必须是字符串,并且需要用双引号括起来。例如: ```json { "key": "value" } ``` #### 4. 注释 JSON 标准中不允许使用注释。以下示例是错误的: ```json { /* 注释 */ "key": "value" } ``` 如果需要注释,可以在代码中处理 JSON 字符串之前移除注释,或者使用支持注释的工具[^2]。 #### 5. 语法验证 为了确保 JSON 数据的有效性,可以使用以下方法进行验证: - 在线验证工具:如 [JSONLint](https://jsonlint.com/) - IDE 插件:如 VS Code 和 IntelliJ IDEA 提供的 JSON 验证功能 - 命令行工具:如 `jq`(适用于 Linux 和 Mac 系统) #### 示例代码 以下是一个完整的 JSON 示例: ```json { "name": "John Doe", "age": 30, "isStudent": false, "courses": ["Math", "Science"], "address": { "street": "123 Main St", "city": "Anytown" } } ``` ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值