ES6:解构赋值

前言 

解构赋值是ES6中新增的一种赋值方式,它可以让我们快速地从数组或者对象中提取出需要的值,并赋值给对应的变量。

赋值策略中,我们可以进一步划分出两种主要的技巧:数组解构赋值和对象解构赋值。这两者在编程中扮演着重要的角色。

数组解构赋值,是一种创新的赋值方式,它允许我们直接从数组中提取值并分配给变量。这种方式简化了代码,提高了效率,使得数据处理更为直观和便捷。

另一方面,对象解构赋值则是针对对象的一种高级赋值技术。它允许我们将对象的属性值直接提取出来,并赋值给相应的变量。这种方式极大地增强了代码的可读性和维护性,使得对象属性的访问和操作更加灵活和简洁。

总的来说,无论是数组解构赋值还是对象解构赋值,都是现代编程语言中的重要特性。它们通过提供更优雅、更高效的赋值方式,提升了代码的质量和开发者的编程体验。

一、数组解构赋值

1.基本数组解构:通过声明变量来从数组中提取值,变量的顺序对应数组的值的顺序。
        let a = [2024,"你好","世界"];
        let [b,c,d] = a;
        console.log(b);//2024
        console.log(c);//你好
        console.log(d);//世界

这里,我定义了一个数组a,然后通过解构赋值将数组中的元素分别赋值给变量bcd

  • b接收数组的第一个元素2024
  • c接收数组的第二个元素"你好"
  • d接收数组的第三个元素"世界"

因此,当我在执行以下console.log()语句时,得到了预期的相应结果。

2.默认值:可以为解构的变量设置默认值,当对象对应的属性不存在或值为undefined时,使用默认值。
        let a = [2024,"你好","世界"];
        let [b,c=2024,d="默认值",e="好的"] = a;
        console.log(b);//2024
        console.log(c);//你好
        console.log(d);//世界
        console.log(e);//好的

在这个例子中:

  • b接收数组的第一个元素2024
  • c应该接收数组的第二个元素"你好",但由于我为c设置了默认值2024,所以如果数组的第二个元素不存在或者为undefined,那么c将被赋值为2024。但在这个例子中,数组的第二个元素是存在的,所以c会被赋值为"你好"
  • d应该接收数组的第三个元素"世界",但由于我为d设置了默认值"默认值",所以如果数组的第三个元素不存在或者为undefined,那么d将被赋值为"默认值"。但在这个例子中,数组的第三个元素是存在的,所以d会被赋值为"世界"
  • e没有对应的数组元素,因此它会使用设置的默认值"好的"

二、对象解构赋值

1.基本对象解构:通过声明变量来从对象中提取值,变量的名称对应对象的属性名称。
 const obj={
            name:"张三",
            age:20,
            run(){
                console.log("测试内容");
            }
        }
        const{name,age,run,test="默认值"}=obj;
        console.log(name)//张三
        run();//测试内容
        console.log(test);//默认值

在这个例子中:

  • name从对象obj中获取name属性的值,即"张三"
  • age从对象obj中获取age属性的值,即20
  • run从对象obj中获取run方法的引用。
  • test尝试从对象obj中获取test属性的值,但由于obj中没有test属性,所以使用我设置的默认值"默认值"

 2.复杂数据的解构赋值通常涉及到嵌套的对象和数组,或者需要使用更复杂的模式来提取和赋值。
 const test={
            number:[1,2,3,4,5],
            test2:{
                name:"张三",
                age:20
            }
        }
        const {number:[a,b,c],test2:{name,age}}=test
        console.log(a)//1
        console.log(age)//20

在这个例子中:

  • number: [a, b, c]从对象testnumber属性(一个数组)中提取出前三个元素,并分别赋值给变量abc
  • test2: { name, age }从对象testtest2属性(另一个对象)中提取出nameage属性的值,并分别赋值给变量nameage
3.字符串的解构:字符串也可以进行解构赋值,这是因为字符串在内部是可以通过索引访问其字符的,类似于一个字符数组
let str = "hello";
const [first, second, third] = str;

console.log(first); //h
console.log(second); //e
console.log(third); //l

在这个例子中,我们使用数组解构赋值的方式从字符串str中提取出前三个字符,并分别赋值给变量firstsecondthird

需要注意的是,虽然字符串可以被解构,但它们本身是不可变的(immutable),这意味着你不能通过改变解构后的单个字符来修改原始字符串。如果你需要操作字符串中的某个字符,通常需要先将字符串转换为字符数组,然后进行操作,再将结果转换回字符串。例如:

const str = "hello";
const chars = str.split(""); // 将字符串转换为字符数组
chars[0] = "H"; // 修改第一个字符
const newStr = chars.join(""); // 将字符数组转换回字符串

console.log(newStr); // Heello

 此外,字符串解构赋值还可以结合剩余运算符(...)来获取剩余的所有字符:

const str = "hello";
const [first, ...rest] = str;

console.log(first); // 输出"h"
console.log(rest); // 输出["e", "l", "l", "o"]

关于解构赋值的探讨至此已大致涵盖,期待这些内容能对大家的学习和理解带来实质性的帮助。然而,鉴于知识的深度和广度,文中可能存在些许疏漏或不足之处。对此作者持开放态度,并热烈欢迎各位读者指出并进行深入讨论。

  • 24
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值