iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Js解构赋值的常见场景有哪些
  • 798
分享到

Js解构赋值的常见场景有哪些

2023-07-05 10:07:20 798人浏览 泡泡鱼
摘要

这篇“js解构赋值的常见场景有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Js解构赋值的常见场景有哪些”文章吧。解构赋

这篇“js解构赋值的常见场景有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Js解构赋值的常见场景有哪些”文章吧。

解构赋值语法是一种 javascript 表达式,通过解构赋值, 可以将属性/值从对象/数组中取出,赋值给其他变量。这种语法是 ECMAscript 6 规范引入了一种新语法,可以更轻松地从数组和对象中获取值。

1. 提取数据

先来看看如何在 JavaScript 中解构对象,可以从这个商品对象的简单示例开始。

const product = {    id: 1,    title: "Nike air Zoom Pegasus 38",    product_image: "/resources/products/01.jpeg",    shown: "White/Pure Platinum/Midnight Navy/Wolf Grey",    price: 120,};const { id, price, title } = product;

这样,就可以通过以下方式访问相应的属性:

console.log(id); // 1console.log(price); // 120console.log(title); // Nike Air Zoom Pegasus 38

解构,能够让代码更加清晰简洁。如果需要解构一个更复杂的对象呢?即对象中的对象。

现在假设需要从商品列表数据中获取其中一个商品的属性,如下:

const products = [    {        id: 1,        title: "Nike Air Zoom Pegasus 38",        price: 120,    },    {        id: 2,        title: "Nike Air Zoom Alphafly NEXT%",        price: 275,    },    {        id: 3,        title: "Nike Zoom Fly 4",        price: 89.0,    },];

在这里,产品列表嵌套了几层,需要访问商品的信息,可以解构尽可能多的级别以获取商品对象的属性。

const [tmp, { id, title, price }] = products;console.log(id); // 2console.log(title); // Nike Air Zoom Alphafly NEXT%console.log(price); // 275

上面的代码仅用于展示其用法,项目开发中不建议再数组中这样获取对象信息。

通常,数据列表不一定非要数组,从获取效率来说,map 对象的访问比数组效率要高。可以将上面的数据改为 map 对象,如下:

const products = {    1: {        title: "Nike Air Zoom Pegasus 38",        price: 120,    },    2: {        title: "Nike Air Zoom Alphafly NEXT%",        price: 275,    },    3: {        title: "Nike Zoom Fly 4",        price: 89.0,    },};const {    2: { id, title, price },} = products;console.log(id); // 2console.log(title); // Nike Air Zoom Alphafly NEXT%console.log(price); // 275

在 JavaScript 中,数据可以是变量和方法,因此解构赋值也适合用在函数参数的定义,如下:

const printArticle = ({ title, remark }) => {    console.log(title);    console.log(remark);};printArticle({    title: "JavaScript 解构赋值",    remark: "解构赋值的实用场景介绍",});

在使用 ReactVue框架时,有很多解构赋值的地方,如方法的引入等等。

2. 别名取值

如果想创建与属性名称不同的变量,那么可以使用对象解构的别名功能。

const { identifier: aliasIdentifier } = expression;

identifier 是要访问的属性的名称,aliasIdentifier 是变量名称。具体用法如下:

const products = {    1: {        title: "Nike Air Zoom Pegasus 38",        price: 120,    },    2: {        title: "Nike Air Zoom Alphafly NEXT%",        price: 275,    },    3: {        title: "Nike Zoom Fly 4",        price: 89.0,    },};const {    2: { price: productPrice },} = products;console.log(productPrice); // 275

3. 动态属性

可以使用动态名称提取到变量属性(属性名称在运行时已知):

const { [propName]: identifier } = expression;

propName 表达式应计算为属性名称(通常是字符串),标识符应指示解构后创建的变量名称,用法如下:

const products = {    1: {        title: "Nike Air Zoom Pegasus 38",        price: 120,    },    2: {        title: "Nike Air Zoom Alphafly NEXT%",        price: 275,    },    3: {        title: "Nike Zoom Fly 4",        price: 89.0,    },};const producTKEy = "1";const { [productKey]: product } = products;console.log(product); // { title: 'Nike Air Zoom Pegasus 38', price: 120 }

上面代码中,可以通过更新 productKey 的值进而使得 product 的值也跟随变化。

4. 对象解构中的 Rest

将 rest 语法添加到解构中,Rest 属性收集那些尚未被解构模式拾取的剩余可枚举属性键。

const { identifier, ...rest } = expression;

解构后,变量标识符包含属性值。 rest 变量是一个具有其余属性的普通对象。

const product = {    title: "Nike Air Zoom Pegasus 38",    price: 120,    quantity: 5,    cateGory_id: 1,    reviews: 9830,    total: 45,};const { title, ...others } = product;console.log(others); // { price: 120, quantity: 5, category_id: 1, reviews: 9830, total: 45 }

对于数组,可以通过 Rest 的实现首尾值的获取:

const numbers = [1, 2, 3];const [head, ...tail] = numbers;console.log(head); // 1console.log(tail); // [ 2, 3 ]

5. 默认值

正如前面介绍的那样可以在解构数组时为其分配默认值:

const RGBA = [255, 34];const [R, G, B = 0, A = 1] = RGBA;console.log(R); // 255console.log(G); // 34console.log(B); // 0console.log(A); // 1

这样,可以将确保在 B、A 未定义的情况下有一个默认值。

以上就是关于“Js解构赋值的常见场景有哪些”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: Js解构赋值的常见场景有哪些

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

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

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

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

下载Word文档
猜你喜欢
  • Js解构赋值的常见场景有哪些
    这篇“Js解构赋值的常见场景有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Js解构赋值的常见场景有哪些”文章吧。解构赋...
    99+
    2023-07-05
  • JavaScript解构赋值的常见场景有哪些
    这篇文章主要为大家展示了“JavaScript解构赋值的常见场景有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript解构赋值的常见场景有哪些”这篇文章吧。1. 提取数据先来看...
    99+
    2023-06-25
  • 聊聊Js解构赋值的5个常见场景和实例
    本篇文章给大家带来了关于JavaScript的相关知识,其中主要跟大家聊一聊js解构赋值的5个常见场景和实例,感兴趣的朋友下面一起来看一下吧,希望对大家有帮助。解构赋值语法是一种 JavaScript 表达式,通过解构赋值, 可以将属性/值...
    99+
    2023-05-14
    JavaScript Vue.js
  • JavaScript解构赋值的5个常见场景与实例教程
    目录前言1. 提取数据 2. 别名取值 3. 动态属性 4. 对象解构中的 Rest 5. 默认值 总结 前言 解构赋值语法是一种 JavaScript 表达式,通过解构赋值, 可以...
    99+
    2024-04-02
  • JS闭包可被利用的常见场景有哪些
    这篇文章给大家分享的是有关JS闭包可被利用的常见场景有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。场景一:采用函数引用方式的setTimeou...
    99+
    2024-04-02
  • Ajax常见应用场景有哪些
    这篇文章将为大家详细讲解有关Ajax常见应用场景有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1 什么是AJAXAJAX(Asynchronous JavaScri...
    99+
    2024-04-02
  • Hadoop MapReduce常见的容错场景有哪些
    这篇文章主要介绍“Hadoop MapReduce常见的容错场景有哪些”,在日常操作中,相信很多人在Hadoop MapReduce常见的容错场景有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操...
    99+
    2024-04-02
  • JavaScript有哪些常见的赋值运算符
    这篇文章主要介绍了JavaScript有哪些常见的赋值运算符,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JavaScript常见赋值运算符...
    99+
    2024-04-02
  • Golang中Context的常见应用场景有哪些
    这篇文章主要讲解了“Golang中Context的常见应用场景有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Golang中Context的常见应用场景有哪些”吧!超时取消假设我们希望H...
    99+
    2023-07-04
  • 代理IP常见的使用场景有哪些
    本篇内容主要讲解“代理IP常见的使用场景有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“代理IP常见的使用场景有哪些”吧!根据隐蔽性,ip代理服务现在可以分为三类。由于价格相对低廉,一般代理...
    99+
    2023-06-20
  • Go语言常见的应用场景有哪些?
    go语言适用于多种场景,包括后端开发、微服务架构、云计算、大数据处理、机器学习,以及构建restful api。其中,使用go构建restful api的简单步骤包括:设置路由器、定义处...
    99+
    2024-04-03
    应用场景 go语言
  • 云主机的常见应用场景有哪些
    云主机的应用场景有:1.企业官网;2.高并发应用或网站;3.高I/O要求数据库;4.访问量波动剧烈的网站;具体分析如下:企业官网网站初始阶段访问量小,可以选择配置的云主机,随着网站发展,可以随时升级云主机配置,或者增加云主机实例数量,无需担...
    99+
    2024-04-02
  • Python Numpy Load API有哪些常见的使用场景?
    Python是一种强大的编程语言,它有很多常用的库,其中一个非常流行的库是Numpy。Numpy是Python的一个科学计算库,它提供了高效的多维数组对象以及很多用于数组操作的函数。在Numpy中,Load API是一个非常重要的函数,它...
    99+
    2023-09-04
    numpy load api
  • Hadoop常用的场景有哪些
    这篇文章主要讲解了“Hadoop常用的场景有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Hadoop常用的场景有哪些”吧!Hadoop是什么随着数据量的急剧增加,遇到的两个最直接的问题...
    99+
    2023-06-02
  • 数组在Java中有哪些常见的应用场景?
    Java是一门广泛应用的编程语言,它有着丰富的数据结构,其中数组是最基础也是最常用的数据结构之一。数组是一种容器,它能够存储多个相同类型的元素,这些元素在内存中是连续存储的。本文将介绍在Java中数组的常见应用场景以及相关的代码实现。 1....
    99+
    2023-07-20
    unix 自然语言处理 数组
  • Javascript 中有哪些解构赋值语法
    本篇文章给大家分享的是有关Javascript 中有哪些解构赋值语法,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。组解构数组解构非常简单。你所...
    99+
    2024-04-02
  • 利用PHP使用Redis常见的使用场景有哪些
    这篇文章主要为大家展示了“利用PHP使用Redis常见的使用场景有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“利用PHP使用Redis常见的使用场景有哪些”这篇文章吧。简单字符串缓存实战$...
    99+
    2023-06-04
  • PHP 函数中引发警告的常见场景有哪些?
    在 php 函数中,警告通常发生在以下场景:变量未定义。函数未定义。无效的函数参数。重复的函数参数。打开文件失败。 PHP 函数中引发警告的常见场景 PHP 函数中的警告是一种非致命错...
    99+
    2024-04-27
    php 警告
  • GIT在GO语言中有哪些常见的应用场景?
    GIT是目前广泛应用于版本控制的工具之一,而GO语言则是近年来备受关注的编程语言之一。两者在实际应用中有着紧密的联系,GIT在GO语言中的应用场景也是非常广泛的,本文将对此进行探讨。 一、代码管理 GIT最基础的应用场景就是代码管理,GO语...
    99+
    2023-07-03
    数据类型 框架 git
  • ES6下javascript解构赋值常见用法总结
    Javascript解构赋值出现的契机: let obj = { a: 1, b: 2 } // 取值 let a =...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作