JSON Object 对象文字

本文介绍了JSON字符串如何表示对象字面量,以及如何通过JSON.parse()方法将其转化为JavaScript对象。同时,讨论了访问和遍历JavaScript对象的两种方式——点表示法和方括号表示法,以及使用for-in循环遍历对象属性的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是一个 JSON 字符串:

          '{"name":"John", "age":30, "car":null}'

在 JSON 字符串中有一个 JSON 对象字面量:

         {"name":"John", "age":30, "car":null}

JSON 对象文字被大括号 {} 包围。

JSON 对象文字包含键/值对。

键和值由冒号分隔。

键必须是字符串,值必须是有效的 JSON 数据类型:

  • string
  • number
  • object
  • array
  • boolean
  • null

每个键/值对由逗号分隔。

注意

将 JSON 对象字面量称为“JSON 对象”是一个常见的错误。

JSON 不能是对象。 JSON 是一种字符串格式。

当数据为字符串格式时,数据仅为 JSON。当它被转换为 JavaScript 变量时,它就变成了 JavaScript 对象。

JavaScript Objects 对象

从 JSON 对象字面量创建 JavaScript 对象:

<!DOCTYPE html>
<html>
<body>

<h2>Creating an Object from a JSON Literal</h2>
<p id="demo"></p>

<script>
const myObj = {"name":"John", "age":30, "car":null};
document.getElementById("demo").innerHTML = myObj.name;
</script>

</body>
</html>

通过解析 JSON 字符串来创建 JavaScript 对象:

<!DOCTYPE html>
<html>
<body>

<h2>Creating an Object Parsing JSON</h2>
<p id="demo"></p>

<script>
const myJSON = '{"name":"John", "age":30, "car":null}';
const myObj = JSON.parse(myJSON);
document.getElementById("demo").innerHTML = myObj.name;
</script>

</body>
</html>

访问对象值

可以使用点 (.) 表示法访问对象值:

<!DOCTYPE html>
<html>
<body>

<h2>Access a JavaScript Object</h2>
<p id="demo"></p>

<script>
const myJSON = '{"name":"John", "age":30, "car":null}';
const myObj = JSON.parse(myJSON);
document.getElementById("demo").innerHTML = myObj.name;
</script>

</body>
</html>

您还可以使用方括号 ([]) 表示法访问对象值:

<!DOCTYPE html>
<html>
<body>

<h2>Access a JavaScript Object</h2>
<p id="demo"></p>

<script>
const myJSON = '{"name":"John", "age":30, "car":null}';
const myObj = JSON.parse(myJSON);
document.getElementById("demo").innerHTML = myObj["name"];
</script>

</body>
</html>

 循环对象

可以使用 for-in 循环遍历对象属性:

<!DOCTYPE html>
<html>
<body>

<h2>Looping Object Properties</h2>
<p id="demo"></p>

<script>
const myJSON = '{"name":"John", "age":30, "car":null}';
const myObj = JSON.parse(myJSON);

let text = "";
for (const x in myObj) {
  text += x + ", ";
}
document.getElementById("demo").innerHTML = text;
</script>

</body>
</html>

 在 for-in 循环中,使用括号表示法访问属性值:

<!DOCTYPE html>
<html>
<body>

<h2>Looping JavaScript Object Values</h2>
<p id="demo"></p>

<script>
const myJSON = '{"name":"John", "age":30, "car":null}';
const myObj = JSON.parse(myJSON);

let text = "";
for (const x in myObj) {
  text += myObj[x] + ", ";
}
document.getElementById("demo").innerHTML = text;
</script>

</body>
</html>

参考地址:JSON Literals

### 将字符串转化为 JSON 数组 在 Python 中,可以通过 `json` 模块将字符串解析为 JSON 对象。以下是具体的实现方式: #### 使用 `json.loads()` 方法 当需要将一个表示 JSON 的字符串转换为对应的 Python 数据结构(如列表或字典),可以使用 `json.loads()` 函数[^2]。 ```python import json # 假设这是一个有效的 JSON 字符串 json_string = '[{"name": "Alice", "age": 25}, {"name": "Bob", "age": 30}]' # 转换为 JSON 数组 (Python 列表) parsed_json_array = json.loads(json_string) print(parsed_json_array) # 输出: [{'name': 'Alice', 'age': 25}, {'name': 'Bob', 'age': 30}] ``` 上述代码展示了如何通过 `json.loads()` 解析 JSON 格式的字符串并将其转换为 Python 列表。需要注意的是,输入的字符串必须是一个合法的 JSON 格式字符串[^3]。 --- #### 处理 PostgreSQL 查询返回的数据 如果从数据库查询得到的结果是以字符串形式存储的 JSON 对象,则同样可以利用 `json.loads()` 进行处理[^4]。 ```python import json # 假设这是从 PostgreSQL 返回的一条记录中的字段值 db_result = '{"key": "value"}' try: parsed_object = json.loads(db_result) print(parsed_object) # 输出: {'key': 'value'} except ValueError as e: print(f"无法解析 JSON 字符串: {e}") ``` 此部分说明了即使是从外部源接收到的 JSON 字符串,也可以安全地尝试解析它,并捕获可能发生的异常情况。 --- ### 注意事项 1. 如果传入的不是有效 JSON 格式的字符串,调用 `json.loads()` 可能会抛出 `ValueError` 或其他错误。 2. 当遇到 `'str' object has no attribute 'read'` 错误时,通常是因为误用了 `json.load()` 而非 `json.loads()`。前者用于读取文件流,后者则针对纯字符串操作。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值