一文带你了解JSON

一文带你了解JSON

一、认识JSON

在目前的开发中,JSON是一种非常重要的数据格式,它并不是编程语言,而是一种可以在服务器和客户端之间传输的数据格式,它可以被任何的编程语言读取和作为数据格式来传递。

  • JSON的使用场景:
    • 网络数据的传输JSON数据;
    • 项目的某些配置文件;
    • 非关系型数据库(NoSQL)将json作为存储格式;

1.1 JSON的基本语法

  • JSON的顶层支持三种类型的值:
    • 简单值:数字(Number)、字符串(String,不支持单引号)、布尔类型(Boolean)、null类型;
    • 对象值:由key、value组成,key是字符串类型,并且必须添加双引号,值可以是简单值、对象值、数组值;
    • 数组值:数组的值可以是简单值、对象值、数组值;
  • 注意事项:
    • 对象的属性名必须使用双引号,值要是字符串也必须使用双引号
    • 键与值之间使用冒号连接, 多个键值对之间使用逗号分隔
    • 复合类型的值只能是数组或对象,不能是函数、正则表达式对象、日期对象。
    • 原始类型的值只有四种:字符串、数值(必须以十进制表示)、布尔值和null(不能使用NaN, Infinity, -Infinityundefined)。
    • 数组或对象最后一个成员的后面,不能加逗号。

二、对象序列化

序列化是将对象状态转换为可保持或传输的格式的过程。与序列化相对的是反序列化,它将流转换为对象。这两个过程结合起来,可以轻松地存储和传输数据。

  • 某些情况下我们希望将JavaScript中的复杂类型转化成JSON格式的字符串,这样方便对其进行处理:
    • 比如我们希望将一个对象保存到localStorage中;
    • 但是如果我们直接存放一个对象,这个对象会被转化成 [object Object] 格式的字符串,并不是我们想要的结果;

在这里插入图片描述

  • JSON序列化/反序列化方法
    • stringify方法:将JavaScript类型转成对应的JSON字符串
    • parse方法:解析JSON字符串,转回对应的JavaScript类型

2.1 JSON序列化

  • JSON.stringify(value[, replacer [, space]])

  • JSON.stringify() 方法将一个 JavaScript 对象或值转换为 JSON 字符串

  • 返回值:一个表示给定值的 JSON 字符串。

  • replacer 参数

    • 如果指定了一个 replacer 函数,则可以选择性地替换值
    • 或者指定的 replacer 是数组,则可选择性地仅包含数组指定的属性
   const stuString1 = JSON.stringify(stu)
    console.log(stuString1)
    // 输出如下:{"name":"zhang","age":19,"sex":"female"}

    // replacer是数组
    const stuString2 = JSON.stringify(stu, ["name", "age"])
    console.log(stuString2)
    // 输出如下: {"name":"zhang","age":19}

// replacer是函数
const stuString3 = JSON.stringify(stu, (key, value) => {
  if (key === "name") {
    return "xiaozhang"
  }
  return value
})
console.log(stuString3);
// 输出如下:{"name":"xiaozhang","age":19,"sex":"female"}
  • space参数
    • space 参数用来控制结果字符串里面的间距,用于美化输出(pretty-print)
    • 如果是一个数字,则在字符串化时每一级别会比上一级别缩进多这个数字值的空格(最多 10 个空格)
    • 该值若小于 1,则意味着没有空格;
    • 如果该参数为字符串(当字符串长度超过 10 个字母,取其前 10 个字母),该字符串将被作为空格;
    • 如果该参数没有提供(或者为 null),将没有空格。
    const stuString1 = JSON.stringify(stu, null, 2)
    console.log(stuString1)

在这里插入图片描述

    const stuString1 = JSON.stringify(stu, null, "\t")
    console.log(stuString1)

在这里插入图片描述

  • toJSON方法
    • 如果一个被序列化的对象拥有 toJSON 方法,那么该 toJSON 方法就会覆盖该对象默认的序列化行为:不是该对象被序列化,而是调用 toJSON 方法后的返回值会被序列化

例如:

    var stu = {
      name: "zhang",
      age: 19,
      sex: "female",
      toJSON: function() {
        return "jean"
      }
    }

在这里插入图片描述

2.2 JSON反序列化

  • JSON.parse() 方法用来解析 JSON 字符串,构造由字符串描述的 JavaScript 值或对象
  • JSON.parse(text[, reviver])
  • 返回值:Object类型,对应给定 JSON 文本的对象/值。
  • 提供可选的 reviver 函数用以在返回之前对所得到的对象执行变换(操作)。
    const stuString = JSON.stringify(stu)
    const info = JSON.parse(stuString, function(key, value) {
      if (key == "age") {
        return value + 2
      }
      return value
    })
    console.log(info);
//输出如下:{name: 'zhang', age: 21, sex: 'female'}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
LVS(Linux Virtual Server)是一种基于 Linux 系统的负载均衡集群技术,它主要用于将网络流量分发到多个服务器上,以提高系统的可靠性、可扩展性和性能。 LVS 集群一般包括四个组件:调度器(LVS 调度器)、前端服务器(负载均衡器)、后端服务器(真实服务器)和存储服务器(用于共享数据)。首先,调度器接收来自客户端的请求,然后根据配置的调度算法(如轮询、加权轮询、最小连接数等)将请求分发到多个前端服务器。前端服务器接收到请求后,通过相应的负载均衡算法将请求转发到后端的真实服务器上进行处理。在整个过程,存储服务器用于存放共享的数据,以确保所有的真实服务器都能获取到相同的数据,并提供一致的服务。 LVS 集群的优点是能够提高网站的稳定性和可靠性,当某一台服务器出现故障时,调度器会自动将请求分发到其他可用的服务器上,从而保证服务的连续性。同时,LVS 集群还能够通过增加前端服务器和后端服务器的数量来提高系统的性能和吞吐量,以满足不断增长的用户需求。 在实际应用,LVS 集群需要合理配置,包括选择合适的调度算法、调整每台服务器的权重、选择适当的硬件设备等。此外,还需要及时监控集群的运行状态,及时发现和解决故障,以确保整个系统的正常运行。 总的来说,LVS 负载均衡集群是一种强大而高效的集群技术,能够帮助企业提高系统的可靠性和性能,是现代互联网应用不可或缺的重要组成部分。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端程序员小张

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值