什么是JSON(详解)

JSON是一种数据格式,常用于数据交换,不是编程语言。它支持字符串、数字、布尔值和null,对象以键值对形式存储,需用双引号包裹。JSON相比XML有更便捷的优势,JavaScript中内置JSON对象,提供`JSON.stringify()`用于序列化成字符串,`JSON.parse()`用于解析JSON字符串。

JSON

  1. 什么是JSON

    =>JSON是一种数据格式,不是编程语言,全称(javascript object Notation)javascript对象表示法,不是只有 javascript可以使用JSON,很多编程语言都有针对JSON格式的解码器。

  2. 语法
    • 基本类型:

      =>可以在JSON中表示字符串,数字,布尔值和null,但是不支持undefined

    • 对象:

      =>可以在JSON格式中出现对象,对象中以键值对的形式存储,但是键名和属性值必须用双引号包裹,键值对中的值可以是简单类型,也可以是复杂数据类型

    • 数组

      =>可以存储任意类型,简单值,对象和数组。

  3. 注意:
    • 布尔值和null也是有效的JSON格式
    • 对象的属性名和属性必须用双引号包裹,这是必须的
    • 对象的属性值可以是简单数据类型,也可以是复杂数据类型
  4. JSON的优势

    利用JSON格式的数据格式,可以方便的将数据结构解析为有用的JavaScript对象,比XML格式优势更为突出便捷

  5. JSON对象
    • ES5中定义了一个JSON对象,可以用来序列化JSON字符串或者将JSON格式字符串解析为javascript对象

      打印结果如下:

      console.log(JSON);
      
      //JSON {Symbol(Symbol.toStringTag): "JSON", parse: ƒ, stringify: ƒ}
      //parse: ƒ parse()
      //stringify: ƒ stringify()
      //Symbol(Symbol.toStringTag): "JSON"
      
    • JSON.stringify( ) 将javascript对象转化为一个JSON格式的字符串 返回该字符串

      =>输出的JSON字符串不包含任何空格和缩进

      var obj= {
                  name:'andy',
                  age:20,
                  gender:'男'
              }
              console.log(JSON.stringify(obj));
      //{"name":"andy","age":20,"gender":"男"}
      
    • JSON.parse( ) 将JSON格式的字符串解析为相对应的javascript值 返回该值

      var str = '{"name":"andy","age":20,"gender":"男"}';
      console.log(JSON.parse(str));
      //{name: "andy", age: 20, gender: "男"}
      
### JSON 格式详解 JSONJavaScript Object Notation)是一种轻量级的数据交换格式,易于人类阅读和编写,同时也便于机器解析和生成[^1]。它的设计目标是成为一种比 XML 更加简单、高效的替代方案。 #### 数据结构 JSON 的核心是由键值对组成的对象以及有序列表构成的数组。以下是其主要组成部分: - **对象**:一组无序的键/值对集合,其中键必须为字符串,而值可以是任何合法的 JSON 类型。 - **数组**:一个有序的值序列。 - **基本数据类型**:支持字符串、数值、布尔值、`null` 和嵌套的对象或数组。 #### 语法示例 下面是一个典型的 JSON 对象示例: ```json { "name": "Alice", "age": 25, "isStudent": false, "skills": ["Python", "Java", "C++"], "address": { "city": "Beijing", "zipCode": "100000" } } ``` 在这个例子中,“name”、“age”等都是键名,对应的值分别为字符串、整数和其他复杂类型的组合[^2]。 ### 使用方法 在 Web 开发领域,JSON 被广泛用于前后端之间的数据传输。通过 JavaScript 或其他编程语言中的内置函数,可以轻松实现 JSON 字符串与原生对象间的转换。 #### 解析 JSON 当接收到服务器返回的 JSON 文本时,通常需要将其转化为程序可以直接操作的形式。例如,在 JavaScript 中可以通过 `JSON.parse()` 方法完成这一过程[^3]。 ```javascript const jsonString = '{"result":"success","code":200}'; const parsedData = JSON.parse(jsonString); console.log(parsedData.result); // 输出 'success' ``` #### 序列化 JSON 反之,如果要发送数据到服务端,则可能需要用 `JSON.stringify()` 将对象转回成字符串形式。 ```javascript const obj = { name: "Bob", age: 30 }; const stringifiedObj = JSON.stringify(obj); console.log(stringifiedObj); // 输出 '{"name":"Bob","age":30}' ``` 需要注意的是,在实际项目里处理来自外部源的 JSON 数据之前应该做充分的安全校验以防潜在风险[^4]。 ### 安全注意事项 尽管 JSON 提供了一种非常方便的方式来表示结构化的信息,但它并非完全没有安全隐患。特别是对于那些未经验证就直接使用的远程 API 返回的结果来说更是如此。所以建议始终遵循最佳实践——仅信任已知可靠的输入并实施适当级别的防护措施对抗恶意行为者尝试利用漏洞发起攻击的可能性。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值