iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >JavaScript中JSON的使用技巧有哪些
  • 608
分享到

JavaScript中JSON的使用技巧有哪些

2023-06-29 10:06:30 608人浏览 薄情痞子
摘要

本篇内容主要讲解“javascript中JSON的使用技巧有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript中jsON的使用技巧有哪些”吧!1. 格式化默认的字符串化器还会

本篇内容主要讲解“javascriptJSON的使用技巧有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript中jsON的使用技巧有哪些”吧!

1. 格式化

默认的字符串化器还会缩小 JSON,看起来很难看

const user = {  name: 'John',  age: 30,  isAdmin: true,  friends: ['Bob', 'Jane'],  address: {    city: 'New York',    country: 'USA'  }};console.log(JSON.stringify(user));//=> {"name":"John","age":30,"isAdmin":true,"friends":["Bob","Jane"],"address":{"city":"New York","country":"USA"}}

JSON.stringify也有一个内置的格式化程序!

console.log(JSON.stringify(user, null, 2));// {//   "name": "John",//   "age": 30,//   "isAdmin": true,//   "friends": [//     "Bob",//     "Jane"//   ],//   "address": {//     "city": "New York",//     "country": "USA"//   }// }

(如果你想知道那个 null 是什么,我们稍后会谈到)

在此示例中,JSON 格式为 2 个缩进空格。

我们还可以指定用于缩进的自定义字符。

console.log(JSON.stringify(user, null, 'lol'));// {// lol"name": "John",// lol"age": 30,// lol"isAdmin": true,// lol"friends": [// lollol"Bob",// lollol"Jane"// lol],// lol"address": {// lollol"city": "New York",// lollol"country": "USA"// lol}// }

2. 隐藏字符串化数据中的某些属性

JSON.stringify第二个参数,这在很大程度上是未知的。它被称为replacer,它是一个函数或数组,用于决定哪些数据保留在输出中,哪些不保留。

这是一个简单的示例,我们可以在其中隐藏passWord用户。

const user = {  name: 'John',  password: '12345',  age: 30};console.log(JSON.stringify(user, (key, value) => {    if (key === 'password') {            return;    }    return value;}));

这是输出:

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

我们可以进一步重构:

function stripKeys(...keys) {    return (key, value) => {        if (keys.includes(key)) {            return;        }        return value;    };}const user = {  name: 'John',  password: '12345',  age: 30,  gender: 'male'};console.log(JSON.stringify(user, stripKeys('password', 'gender')))

输出:

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

还可以传递一个数组来仅获取某些键:

const user = {    name: 'John',    password: '12345',    age: 30}console.log(JSON.stringify(user, ['name', 'age']))

输出相同的东西。

这也适用于数组。如果你有一大堆蛋糕:

const cakes = [    {        name: 'Chocolate Cake',        recipe: [            'Mix flour, sugar, cocoa powder, baking powder, eggs, vanilla, and butter',            'Mix in milk',            'Bake at 350 degrees for 1 hour',            // ...        ],        ingredients: ['flour', 'sugar', 'cocoa powder', 'baking powder', 'eggs', 'vanilla', 'butter']    },    // tons of these];

我们可以轻松地做同样的事情,并且替换器将应用于每个蛋糕:

const cakes = [    {        name: 'Chocolate Cake',        recipe: [            'Mix flour, sugar, cocoa powder, baking powder, eggs, vanilla, and butter',            'Mix in milk',            'Bake at 350 degrees for 1 hour',            // ...        ],        ingredients: ['flour', 'sugar', 'cocoa powder', 'baking powder', 'eggs', 'vanilla', 'butter']    },    // tons of these];console.log(JSON.stringify(cakes, ['name']))

我们得到这个:

[{"name":"Chocolate Cake"},{"name":"Vanilla Cake"},...]

3.使用toJSON创建自定义输出格式

如果一个对象实现了该toJSON函数,JSON.stringify将使用它来对数据进行字符串化。

考虑一下:

class Fraction {  constructor(n, d) {    this.numerator = n;    this.denominator = d;  }}console.log(JSON.stringify(new Fraction(1, 2)))

这将输出{"numerator":1,"denominator":2}. 但是如果我们想用一个字符串替换它1/2呢?

进入toJSON

class Fraction {  constructor(n, d) {    this.numerator = n;    this.denominator = d;  }  toJSON() {      return `${this.numerator}/${this.denominator}`  }}console.log(JSON.stringify(new Fraction(1, 2)))

JSON.stringify尊重toJSON财产和产出"1/2"。

4. 恢复数据

我们上面的分数示例效果很好。但是如果我们想恢复数据呢?当我们再次解析 JSON 时,如果分数能神奇地返回,那不是很酷吗?我们可以!

进入复活者!

class Fraction {  constructor(n, d) {    this.numerator = n;    this.denominator = d;  }  toJSON() {      return `${this.numerator}/${this.denominator}`  }  static fromJSON(key, value) {    if (typeof value === 'string') {        const parts = value.split('/').map(Number);        if (parts.length === 2) return new Fraction(parts);    }    return value;  }}const fraction = new Fraction(1, 2);const stringified = JSON.stringify(fraction);console.log(stringified);// "1/2"const revived = JSON.parse(stringified, Fraction.fromJSON);console.log(revived);// Fraction { numerator: 1, denominator: 2 }

我们可以传递第二个参数JSON.parse来指定 reviver 函数。恢复器的工作是将字符串化数据“恢复”回其原始形式。在这里,我们传递了一个 reviver,它是类的静态fromJSON属性Fraction。

在这种情况下,reviver 检查该值是否是一个有效的分数,如果是,它会创建一个新Fraction对象并返回它。

有趣的事实:此功能用于内置的 Date 对象。尝试查找Date.prototype.toJSON

这就是为什么它有效:

console.log(JSON.stringify(new Date()))//=> '"2022-03-01T06:28:41.308Z"'

要恢复日期,我们可以使用JSON.parse:

function reviveDate(key, value) {    const regex = /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d{1,}|)Z$/;    if (typeof value === "string" && regex.test(value)) {        return new Date(value);    }    return value;}console.log(JSON.parse('"2022-03-01T06:28:41.308Z"', reviveDate))//=> Tue Mar 01 2022 06:28:41 GMT-0700 (Pacific Daylight Time)

5.使用revivers隐藏数据

与解析器一样,恢复器也可用于隐藏数据。它以相同的方式工作。

这是一个例子:

const user = JSON.stringify({  name: 'John',  password: '12345',  age: 30});console.log(JSON.parse(user, (key, value) => {    if (key === 'password') {            return;    }    return value;}));

这是输出:

{ name: 'John', age: 30 }

到此,相信大家对“JavaScript中JSON的使用技巧有哪些”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: JavaScript中JSON的使用技巧有哪些

本文链接: https://www.lsjlt.com/news/324193.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中JSON的使用技巧有哪些
    本篇内容主要讲解“JavaScript中JSON的使用技巧有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript中JSON的使用技巧有哪些”吧!1. 格式化默认的字符串化器还会...
    99+
    2023-06-29
  • JavaScript中的使用技巧有哪些
    这篇文章主要介绍了JavaScript中的使用技巧有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。&& 和 || 的妙用...
    99+
    2024-04-02
  • JavaScript的使用技巧有哪些
    今天小编给大家分享一下JavaScript的使用技巧有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、过滤唯一值Set...
    99+
    2023-07-02
  • 使用JavaScript技巧有哪些
    小编给大家分享一下使用JavaScript技巧有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!JS-Tips控制台提示代码执...
    99+
    2024-04-02
  • JavaScript使用技巧有哪些
    本篇内容主要讲解“JavaScript使用技巧有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript使用技巧有哪些”吧!1. 过滤唯一值ES6 引入了 Set 对象和延展(sp...
    99+
    2023-06-27
  • JavaScript使用数组技巧有哪些
    这篇文章主要为大家展示了“JavaScript使用数组技巧有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript使用数组技巧有哪些”这篇文章吧。数组是Javascript最常见...
    99+
    2023-06-21
  • JavaScript中Array的实用技巧有哪些
    这篇文章主要介绍“JavaScript中Array的实用技巧有哪些”,在日常操作中,相信很多人在JavaScript中Array的实用技巧有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,...
    99+
    2024-04-02
  • JavaScript的技巧有哪些
    本篇文章给大家分享的是有关JavaScript的技巧有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。不少人有五年的 JavaScript ...
    99+
    2024-04-02
  • 实用的JavaScript技巧有哪些
    本篇内容主要讲解“实用的JavaScript技巧有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“实用的JavaScript技巧有哪些”吧!1 &nd...
    99+
    2024-04-02
  • 好用的JavaScript技巧有哪些
    这篇文章将为大家详细讲解有关好用的JavaScript技巧有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。数组去重数组去重可能比您想象的更容易:var j&...
    99+
    2024-04-02
  • JavaScript字符串的使用技巧有哪些
    这篇文章主要讲解了“JavaScript字符串的使用技巧有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript字符串的使用技巧有哪些”吧!1.如何多次复制一个字符串JS 字...
    99+
    2023-06-27
  • javascript实用技巧有哪些
    本篇内容介绍了“javascript实用技巧有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、js整数的操作使用|0和~~可以将浮点转...
    99+
    2023-06-25
  • 好用JavaScript技巧有哪些
    这篇文章主要讲解了“好用JavaScript技巧有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“好用JavaScript技巧有哪些”吧!1.获取数组的最...
    99+
    2024-04-02
  • MySQL中的使用技巧有哪些
    这篇文章主要介绍“MySQL中的使用技巧有哪些”,在日常操作中,相信很多人在MySQL中的使用技巧有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL中的使用技巧有...
    99+
    2024-04-02
  • Javascript中有哪些调试技巧
    小编给大家分享一下Javascript中有哪些调试技巧,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. 不要使用alert首先...
    99+
    2024-04-02
  • JavaScript条件判断的使用技巧有哪些
    本文小编为大家详细介绍“JavaScript条件判断的使用技巧有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript条件判断的使用技巧有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。假如我...
    99+
    2023-07-05
  • Dreamweaver中有哪些使用技巧
    这篇文章给大家分享的是有关Dreamweaver中有哪些使用技巧的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。从外部文档中粘贴时,如果不想要其格式,只要文字,可以使用“Edit->paste as text...
    99+
    2023-06-08
  • Linux中有哪些使用技巧
    这篇文章主要为大家展示了“Linux中有哪些使用技巧”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux中有哪些使用技巧”这篇文章吧。文中软件安装命令以 Ubuntu 为例,其它发行版类似。...
    99+
    2023-06-29
  • JavaScript有哪些小技巧
    这篇文章主要为大家展示了“JavaScript有哪些小技巧”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript有哪些...
    99+
    2024-04-02
  • 常用JavaScript小技巧有哪些
    这篇文章主要介绍“常用JavaScript小技巧有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“常用JavaScript小技巧有哪些”文章能帮助大家解决问题。1.通过条件判断向对象添加属性con...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作