Что такое деструктурирующее назначение и его использование? - PullRequest
0 голосов
/ 09 февраля 2019

Я читал о Разрушающем назначении , представленном в ES6.

Какова цель этого синтаксиса, почему он был введен, и каковы некоторые примеры того, как его можно использоватьна практике?

1 Ответ

0 голосов
/ 09 февраля 2019

Что такое присвоение деструктуры?

Синтаксис присвоения являетсяВыражение JavaScript, позволяющее распаковывать значения из массивов или свойства объектов в отдельные переменные.

Преимущества

A. Делает код сжатым и более читаемым.

B. Мы можем легко избежать повторяющихся разрушающих выражений.

Некоторые варианты использования

1.Чтобы получить значения в переменной из Objects, массив

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.Чтобы извлечь значения из параметров в отдельные переменные

const fn = ({ prop }) => {
  console.log(prop);
};
fn({ prop: 'foo' });


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


const fn2 = ([item1, item2]) => {
  console.log(item1);
  console.log(item2);
};
fn2(['bar', 'baz']);

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.Чтобы получить подмножество объекта

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)
...