mdn 참고
https://developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Operators/Destructuring_assignment
그 외 예제 많은 사이트
https://hacks.mozilla.org/2015/05/es6-in-depth-destructuring/
개인 공부용 으로 작성한 내용으로 mdn 과 동일한 내용입니다.
구조 분해 할당 구문은 배열이나 객체의 속성을 해체하여 그 값을 개별 변수에 담을 수 있게 하는 JavaScript 표현식입니다.
var a,b,rest;
[a,b] = [10,20]
console.log(a); // 10
console.log(b); // 20
[a, b, ...rest] = [10, 20, 30, 40, 50];
console.log(a); // 10
console.log(b); // 20
console.log(rest); // [30, 40, 50]
({a, b, ...rest} = {a: 10, b: 20, c: 30, d: 40});
console.log(a); // 10
console.log(b); // 20
console.log(rest); // {c: 30, d: 40}
({f, g, ...rest} = {a: 10, b: 20, c: 30, d: 40});
console.log(f); // undefined
console.log(g); // undefined
({b, a, ...rest} = {a: 10, b: 20, c: 30, d: 40});
console.log(b); // 20
console.log(a); // 10
var x = [1, 2, 3, 4, 5];
var [y, z] = x;
console.log(y); // 1
console.log(z); // 2
var foo = ["one", "two", "three"];
var [one, two, three] = foo;
console.log(one); // "one"
console.log(two); // "two"
console.log(three); // "three"
만약 var one, two, three = foo; 할시
console.log(one); // undefined
console.log(two); // undefined
console.log(three); // ["one", "two", "three"]
var a, b;
[a, b] = [1, 2];
console.log(a); // 1
console.log(b); // 2
var a, b;
[a=5, b=7] = [1];
console.log(a); // 1
console.log(b); // 7
var a = 1;
var b = 3;
[a, b] = [b, a]
console.log(a); // 3
console.log(b); // 1
function f(){
return [1,2];
}
var a,b
[a,b] = f()
console.log(a) // 1
console.log(b) // 2
function f(){
return [1,2,3]
}
var [a, ,b] = f()
console.log(a) // 1
console.log(b) // 3
var [a, ...b] = [1,2,3]
console.log(a) // 1
console.log(b) // [2,3]
var [a, b, ...c] = [1,2,3]
console.log(a) // 1
console.log(b) // 2
console.log(c) // [3]
function parseProtocol(url) {
var parsedURL = /^(\w+)\:\/\/([^\/]+)\/(.*)$/.exec(url);
if (!parsedURL) {
return false;
}
console.log(parsedURL); // ["https://developer.mozilla.org/en-US/Web/JavaScript", "https", "developer.mozilla.org", "en-US/Web/JavaScript"]
var [, protocol, fullhost, fullpath] = parsedURL;
return protocol;
}
console.log(parseProtocol('https://developer.mozilla.org/en-US/Web/JavaScript')); // "https"
var obj = {p:42, q:true}
var {p, q} = obj;
console.log(p); // 42
console.log(q); // true
var obj = {p:42, q:true}
var {a, b} = obj;
console.log(a); // undefined
console.log(b); // undefined
var a, b;
({a, b} = {a: 1, b: 2});
할당 문을 둘러싼 ( .. )는 선언 없이 객체 리터럴(object literal) 비구조화 할당을 사용할 때 필요한 구문입니다.
{a, b} = {a:1, b:2}는 유효한 독립 구문이 아닙니다. 좌변의 {a, b}이 객체 리터럴이 아닌 블록(?)으로 간주되기 때문입니다.
하지만, ({a, b} = {a:1, b:2})는 유효한데, var {a, b} = {a:1, b:2}와 같습니다.
( .. ) 표현식 앞에는 세미콜론이 있어야 합니다. 그렇지 않을 경우 이전 줄과 연결되어 함수를 실행하는데 이용될 수 있습니다.
var obj = {p:42, q:true};
var {p:foo, q:bar} = obj
console.log(foo) // 42
console.log(bar) // true
var {a=10, b=5} = {a:3};
console.log(a) // 3
console.log(b) // 5
var { a: aa=5 b:bb=5} = {a:3};
console.log(aa); // 3
console.log(bb); // 5
var metadata = {
title : "Scratchpad"
translations : [
{
locale : "de",
localization_tags : [],
last_edit : "2014-04-14T08:43:37",
url : "/de/docs/Tools/Scratchpad"
title : "JavaScript-Umgebung"
} ],
url : "/en-US/docs/Tools/Scratchpad"
};
var { title: englishTitle, translations: [{ title: localeTitle }] } = metadata;
console.log(englishTitle); // "Scratchpad"
console.log(localeTitle); // "JavaScript-Umgebung"
var people = [
{
name : 'Mike Smith',
family : {
mother : 'Jane Smith',
father : 'Harry Smith',
sister : 'Samantha Smith'
},
age : 35
},
{
name : 'Tom Jones',
family : {
mother : 'Norah Jones',
father : 'Richard Jones',
sister : 'Howard Jones'
},
age : 35
}
];
for (var {name: n, family: { father: f } } of people) {
console.log('Name: ' + n + ', Father: ' + f);
}
// 'Name: Mike Smith, Father: Harry Smith'
// 'Name: Tom Jones, Father: Richard Jones'
function userId({id}){
return id;
}
function whois({displayName : displayName, fullName : {firstName : name}}){
console.log(displayName + ' is ' + name);
}
var user = {
id : 42,
displayName : 'jdoe',
fullName : {
firstName : 'John',
lastName : 'Doe'
}
};
console.log('userId: ' + userId(user); // 'userId: 42"
whois(user) // 'jdoe is John'
let key = 'z';
let { [key]:foo} = {z:'bar'};
console.log(foo) // 'bar'
let {a, b, ...rest} = {a: 10, b: 20, c: 30, d: 40}
a; // 10
b; // 20
rest; // { c: 30, d: 40 }
const foo = {'fizz-buzz':true};
const {'fizz-buzz':fizzBuzz} = foo;
console.log(fizzBuzz) // true