当前位置: 首页 > 面试题库 >

JavaScript什么是解构赋值及其用途?

有玄天
2023-03-14
问题内容

我一直在阅读有关ES6中引入的解构分配的信息。

该语法的目的是什么,为什么要引入它,以及在实践中如何使用它的一些示例?


问题答案:

什么是销毁工作?

解构赋值 语法是JavaScript表达式,使得它可以从阵列解压缩的值,或从属性的对象,为不同的变量。

  • [MDN]

优点

*答 *: 使代码简明易懂。

B. 我们可以轻松避免重复破坏表达。

一些用例

1.要从Objects,array获取变量中的值

let obj = { 'a': 1,'b': {'b1': '1.1'}}

let {a,b,b:{b1}} = obj

console.log('a--> ' + a, '\nb--> ', b, '\nb1---> ', b1)



let obj2 = { foo: 'foo' };

let { foo: newVarName } = obj2;

console.log(newVarName);



let arr = [1, 2, 3, 4, 5]

let [first, second, ...rest] = arr

console.log(first, '\n', second, '\n', rest)

2.在任何地方将一个阵列与另一个阵列合并。

let arr = [2,3,4,5]

let newArr = [0,1,...arr,6,7]

console.log(newArr)

3.仅更改对象中的所需属性

let arr = [{a:1, b:2, c:3},{a:4, b:5, c:6},{a:7, b:8, c:9}]



let op = arr.map( ( {a,...rest}, index) => ({...rest,a:index+10}))



console.log(op)

4.创建对象的浅表副本

let obj = {a:1,b:2,c:3}

let newObj = {...obj}

newObj.a = 'new Obj a'



console.log('Original Object', obj)

console.log('Shallow copied Object', newObj)

5.将参数中的值提取到独立变量中

// Object destructuring:

const fn = ({ prop }) => {

  console.log(prop);

};

fn({ prop: 'foo' });





console.log('------------------');





// Array destructuring:

const fn2 = ([item1, item2]) => {

  console.log(item1);

  console.log(item2);

};

fn2(['bar', 'baz']);





console.log('------------------');





// Assigning default values to destructured properties:



const fn3 = ({ foo="defaultFooVal", bar }) => {

  console.log(foo, bar);

};

fn3({ bar: 'bar' });

6.从对象获取动态键值

let obj = {a:1,b:2,c:3}

let key = 'c'

let {[key]:value} = obj



console.log(value)

7.从具有某些默认值的其他对象构建对象

let obj = {a:1,b:2,c:3}

let newObj = (({d=4,...rest} = obj), {d,...rest})

console.log(newObj)

8.交换价值

const b = [1, 2, 3, 4];

[b[0], b[2]] = [b[2], b[0]]; // swap index 0 and 2



console.log(b);

9.获取对象的子集

  • 9.1 对象的子集:

    const obj = {a:1, b:2, c:3},
    

    subset = (({a, c}) => ({a, c}))(obj); // credit to Ivan N for this function

    console.log(subset);

  • 9.2 使用逗号运算符并解构来获取对象的子集:

    const object = { a: 5, b: 6, c: 7  };
    

    const picked = ({a,c}=object, {a,c})

    console.log(picked); // { a: 5, c: 7 }

10.做数组到对象的转换:

const arr = ["2019", "09", "02"],

date = (([year, day, month]) => ({year, month, day}))(arr);



console.log(date);

11.在功能中设置默认值。

function someName(element, input,settings={i:"#1d252c", i2:"#fff",...input}){

    console.log(settings.i)

    console.log(settings.i2)

}



someName('hello', {i:'#123'})

someName('hello', {i2:'#123'})

12.获取属性,例如length从数组,函数名称,参数数量等。

let arr = [1,2,3,4,5];



let {length} = arr;



console.log(length);



let func = function dummyFunc(a,b,c) {

  return 'A B and C';

}



let {name, length:funcLen} = func;



console.log(name, funcLen);


 类似资料:
  • 我一直在阅读ES6中介绍的解构任务。 这个语法的目的是什么,为什么引入它,以及在实践中如何使用它的一些示例是什么?

  • JavaScript 中最常用的两种数据结构是 Object 和 Array。 对象让我们能够创建通过键来存储数据项的单个实体,数组则让我们能够将数据收集到一个有序的集合中。 但是,当我们把它们传递给函数时,它可能不需要一个整体的对象/数组,而是需要单个块。 解构赋值 是一种特殊的语法,它使我们可以将数组或对象“拆包”为到一系列变量中,因为有时候使用变量更加方便。解构操作对那些具有很多参数和默认值

  • 本文向大家介绍JavaScript中的赋值运算符是什么?,包括了JavaScript中的赋值运算符是什么?的使用技巧和注意事项,需要的朋友参考一下 使用赋值运算符,您可以将值分配给变量。JavaScript支持以下赋值运算符- 序号 运算符和说明 1 =(简单分配) 从右侧操作数到左侧操作数分配值 例如: C = A + B将A + B的值分配给C 2 + =(添加和分配) 将右操作数添加到左操作

  • 问题内容: 我对于过去几天来遇到的Zookeeper港口来说是个新手。 我曾两次用 zookeeper port 关键字介绍过: 在配置neo4j数据库群集(链接)时, 在运行已编译的voltdb目录(链接)时(请参阅网络配置参数) 然后,我遇到了Apache Zookeeper (我想它与分布式应用程序有关,我也是分布式应用程序的新手)。因此我想到一个问题: 在上述两种情况下,Apache Zo

  • 在很多流行的编程语言里,都有解构赋值的概念,比如Perl,Python ES6中也加入了类似的赋值语句,比以前的赋值操作更灵活,更快捷 正文 数组的解构赋值很好理解,就是按照对应位置,对变量赋值: let [a, b, c] = [1, 2, 3] 相当于 let a = 1 let b = 2 let c = 3 支持数组嵌套,也支持等号两边结构不同的情况 如果变量对应不上值,这个变量就是und

  • 怎么通过解构赋值的方式给dir默认值?