JS里的{ }大括号和[ ]中括号的用法——看懂JSON结构

本文详细介绍了JavaScript中对象和数组的基本概念及使用方法,包括如何定义对象和数组、访问其属性和元素,以及如何组合使用它们创建复杂的数据结构。

一、{ } 大括号,表示定义一个对象,大部分情况下要有成对的属性和值,或是函数。

如:var LangShen = {"Name":"Langshen","AGE":"28"};

上面声明了一个名为“LangShen”的对象,多个属性或函数用,(逗号)隔开,因为是对象的属性,

所以访问时,应该用.(点)来层层访问:LangShen.Name、LangShen.AGE,当然我们也可以用数组的方式来访问,如:LangShen["Name"]、LangShen["AGE"],结果是一样的。

该写法,在JSON数据结构中经常用,除此之外,我们平时写函数组的时候,也经常用到,如:

var LangShen = {
      Name = function(){
                 return "LangShen";
                  },

     Age = function(){
                return "28";
                }

}

调用方式差不多,因为是函数组,所以要加上(),如:alert( LangShen.Name() );

二、[ ]中括号,表示一个数组,也可以理解为一个数组对象。

如:var LangShen = [ "Name","LangShen","AGE","28" ];

很明显,每个值或函数,都是独立的,多个值之间只用,(逗号)隔开,因为是数组对象,所以它等于:

var LangShen = Array( "Name","LangShen","AGE","28" );

访问时,也是和数组一样,alert( LangShen[0] );

三、{ } 和[ ] 一起使用,我们前面说到,{ } 是一个对象,[ ] 是一个数组,我们可以组成一个对象数组,如:

var LangShen = { "Name":"Langshen",
                          "MyWife":[ "LuLu","26" ],
                          "MySon":[{"Name":"Son1"},{"Name":"Son2"},{"Name":"Son3"}] 
}

从上面的结构来看,是一个对象里面的第一项是个属性,第二项是一个数组,第三个是包含有多个对象的数组。调用起来,也是一层一层访问,对象的属性用.(点)叠加,数组用 [下标] 来访问。

如:alert( LangShen.MySon[1].Name ) ;

### 解决包含大括号中括号转义字符的复杂JSON字符串解析问题 在处理复杂的 JSON 字符串时,尤其是当字符串中包含大括号 `{}`、中括号 `[]` 转义字符(如 `\`)时,需要特别注意 JSON 的序列化反序列化规则。以下是解决 JSON 解析报错问题的方法: #### 1. 使用 JSON 序列化工具 直接拼接 JSON 字符串容易导致转义错误或格式不正确。推荐使用专业的 JSON 序列化工具,例如 C# 中的 `JsonConvert.SerializeObject` 或 Python 中的 `json.dumps`,它们能够自动处理字符串中的特殊字符[^1]。 示例代码(C#): ```csharp using Newtonsoft.Json; var updateObj = new { test = 5 }; var j = new Newtonsoft.Json.Linq.JObject(); j.Add("id", 21); j.Add("extra", JsonConvert.SerializeObject(updateObj)); string json = j.ToString(); // 正确的 JSON 字符串 ``` 示例代码(Python): ```python import json update_obj = {"test": 5} data = { "id": 21, "extra": json.dumps(update_obj) # 自动处理转义 } json_string = json.dumps(data) print(json_string) ``` #### 2. 转义特殊字符 如果必须手动构建 JSON 字符串,则需要对特殊字符进行转义。JSON 标准要求对以下字符进行转义:`"`、`\`、`/`、`\b`、`\f`、`\n`、`\r` `\t`。此外,大括号 `{}` 中括号 `[]` 在字符串中不需要额外转义,但嵌套 JSON 对象时需确保外层对象的引号正确[^2]。 示例: ```json { "id": 21, "extra": "{\"test\": 5}" // 内部 JSON 对象的双引号需要转义 } ``` #### 3. 避免字符串拼接错误 在动态生成 JSON 字符串时,避免直接拼接字符串。例如,以下拼接方式会导致解析失败: ```csharp string json = "{ \"id\":21,\"extra\":\"" + JsonConvert.SerializeObject(updateObj) + "\" }"; ``` 正确的做法是使用 JSON 构建工具或字典结构生成完整的 JSON 字符串。 #### 4. 处理 Unicode 编码 JSON 标准支持 Unicode 编码,某些解析器可能会将非 ASCII 字符转换为 Unicode 转义序列(如 `\uXXXX`)。如果需要保持原始字符,可以检查解析器是否支持禁用 Unicode 转义[^2]。 #### 5. 测试验证 在实际应用中,建议对生成的 JSON 字符串进行验证。可以使用在线 JSON 验证工具或编程语言内置的 JSON 解析函数来确保格式正确。 --- ### 示例代码总结 #### C# 示例 ```csharp using Newtonsoft.Json; using Newtonsoft.Json.Linq; var updateObj = new { test = 5 }; var j = new JObject(); j.Add("id", 21); j.Add("extra", JsonConvert.SerializeObject(updateObj)); string json = j.ToString(); // 输出: {"id":21,"extra":"{\"test\":5}"} ``` #### Python 示例 ```python import json update_obj = {"test": 5} data = { "id": 21, "extra": json.dumps(update_obj) # 自动处理转义 } json_string = json.dumps(data) # 输出: {"id": 21, "extra": "{\"test\": 5}"} ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值