js解析与序列化json数据(二)序列化探讨

JS解析与序列化JSON数据(二) - 序列化探讨

什么是序列化?

序列化是指将对象(Object)、数组(Array)等复杂的数据类型转换成字符串的过程,方便在不同平台上的传输和存储。在JavaScript中,序列化的主要应用是在数据传输和存储时,将复杂的数据类型转换为字符串,再通过反序列化,将字符串转回原来的数据类型。

序列化方法

JavaScript中常用的序列化方法有两种:JSON.stringify()和toString()

JSON.stringify()

JSON.stringify(obj, [replacer], [space])方法可以将一个JavaScript对象序列化成JSON字符串,其中,第一个参数是要序列化的对象,第二个参数可选,可以是一个函数,也可以是一个数组,用来过滤要序列化的属性,第三个参数也可选,用来控制JSON字符串的缩进和格式。

let foo = {name:'Jack', age:18, gender:'male'};
let json = JSON.stringify(foo);
console.log(json);  // {"name":"Jack","age":18,"gender":"male"}

toString()

toString()方法将对象转换为字符串,但它不能实现JSON数据的生成,仅限于将对象转换为字符串。

let foo = {name:'Jack', age:18, gender:'male'};
let str = foo.toString();
console.log(str);  // [object Object]

序列化示例

下面是两个序列化的示例:

示例一

let movie = {
  title: 'The Shawshank Redemption',
  actor: {
    name: 'Tim Robbins',
    age: 62,
    gender: 'male'
  },
  director: {
    name: 'Frank Darabont',
    age: 60,
    gender: 'male'
  }
}

let json_movie = JSON.stringify(movie);
console.log(json_movie);

执行结果:

{
  "title":"The Shawshank Redemption",
  "actor":{
    "name":"Tim Robbins",
    "age":62,
    "gender":"male"
  },
  "director":{
    "name":"Frank Darabont",
    "age":60,
    "gender":"male"
  }
}

示例二

let person = {
  name:'Tom',
  age:28,
  gender:'male',
  profession:'Engineer',
  interests:['reading','music','travel'],
  setAddress:function(city, area){
    this.address = {
      city:city,
      area:area
    }
  }
}

person.setAddress('Shanghai','Pudong');

let json_person = JSON.stringify(person, ['name', 'age', 'interests', 'address']);
console.log(json_person);

执行结果:

{
  "name":"Tom",
  "age":28,
  "interests":["reading","music","travel"],
  "address":{
    "city":"Shanghai",
    "area":"Pudong"
  }
}

以上是JS解析与序列化JSON数据(二) - 序列化探讨的完整攻略,其中包含两个示例说明。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:js解析与序列化json数据(二)序列化探讨 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • FireFox JavaScript全局Event对象

    FireFox JavaScript全局Event对象 概述 在 FireFox JavaScript 中,Event 对象是一个全局的对象,它代表着一个事件,包含了事件的相关信息,如事件类型,目标元素等。我们可以使用 Event 对象来获取事件信息。 使用方法 获取事件类型 在事件处理函数中,我们可以使用 event.type 属性来获取事件的类型,例如:…

    JavaScript 2023年6月10日
    00
  • jQuery中弹出iframe内嵌页面元素到父页面并全屏化的实例代码

    下面是详细的攻略: 1. 简介 在前端开发中,我们经常需要弹出新的窗口来显示一些元素,比如图片、视频等等。而 iframe 内嵌页面作为一种常见的弹窗方式,具有以下优点: 可以在父页面的基础上再添加一层,实现更加智能化的逻辑; 可以实现异步加载问题。 而全屏化则是为了充分利用屏幕空间,提升用户体验。在 jQuery 中实现这样的功能还是很简单的,下面我们就来…

    JavaScript 2023年6月11日
    00
  • JS常用字符串方法(推荐)

    JS常用字符串方法攻略 在JavaScript中,字符串是一种常见数据类型,而对字符串的操作也是开发者日常开发过程中必不可少的操作。这里将介绍JS中常见的字符串操作方法。 字符串的长度 字符串对象的length属性可以返回字符串中字符的个数。例如: var str = "Hello World"; console.log(str.leng…

    JavaScript 2023年5月19日
    00
  • JavaScript 中有关数组对象的方法(详解)

    JavaScript 中有关数组对象的方法(详解) 数组是 JavaScript 中非常常用的数据结构。在 JavaScript 中,数组对象有许多方法可以使用,比如添加元素、删除元素、查找元素等等。本文将详细介绍 JavaScript 中有关数组对象的方法。 数组的创建 在 JavaScript 中创建一个数组对象有多种方法: 使用字面量表达式 const…

    JavaScript 2023年5月27日
    00
  • js转义字符介绍

    JS转义字符介绍 在编写JavaScript代码时,有时需要在字符串中使用一些特殊字符,如单引号、双引号、反斜杠等。这些特殊字符如果不进行转义,会导致代码执行出错或产生意外的结果。JS提供了一些转义字符,可以帮助我们正确地表示和使用这些特殊字符。 转义字符列表 下面是JS中常用的转义字符列表: 转义字符 描述 \\ 反斜杠符号 \’ 单引号符号 \” 双引号…

    JavaScript 2023年5月19日
    00
  • Javascript闭包演示代码小结

    Javascript闭包演示代码小结 Javascript中的闭包是一个非常重要的概念,许多初学者对此有些困惑,下面是我对闭包的探究过程及代码演示,希望对大家有所帮助。 什么是闭包 闭包是指有权访问另一个函数作用域中的变量的函数。 在Javascript中,函数是第一类对象,可以像普通变量一样传递,所以函数中定义的变量在函数外部也可以访问,但是如果在外部将函…

    JavaScript 2023年6月10日
    00
  • javascript实现循环广告条效果

    让我来为您详细讲解“javascript实现循环广告条效果”的完整攻略。 1. 实现思路 要实现循环广告条效果,需要一个滚动容器和多个图片元素,通过JavaScript动态设置滚动容器的left属性,使其滚动。 具体实现思路如下: 使用HTML和CSS构建基本布局,包括一个滚动容器和多个图片元素; 使用JavaScript动态获取滚动容器和图片元素的宽度,计…

    JavaScript 2023年6月11日
    00
  • JavaScript进阶教程(第一课)第2/3页

    接下来我将详细讲解“JavaScript进阶教程(第一课)第2/3页”的完整攻略。 概述 本教程旨在帮助读者提升JavaScript编程技能,涵盖了Javascript的基础知识和进阶知识。本教程包含多个章节,前面几个章节将介绍Javascript的基础内容,而后面的章节将会深入介绍Javascript的优化和进阶知识,包括如何使用高级Javascript技…

    JavaScript 2023年5月17日
    00
合作推广
合作推广
分享本页
返回顶部