AR삽질러

JavaScript - Spread연산자와 Rest매개변수 (15) 본문

WEB/JavaScript

JavaScript - Spread연산자와 Rest매개변수 (15)

아랑팡팡 2024. 8. 20. 19:11
728x90

 

Spread연산자와 Rest매개변수

 

1. JavaScript - Spread연산자와 Rest매개변수란

 - 문법적으로 동일한 ...을 사용하지만 목적과 용도가 다르다.

 

2. Spread연산자

 - 배열이나 객체의 요소들을 개별적으로 펼쳐서 다른 배열이나 객체에 복사하거나 함수의 인수로 전달할 때 사용된다.

let arr1 = [1, 2, 3];
let arr2 = [4, ...arr1, 5, 6];
console.log(arr2);

...arr1는 arr1배열의 요소들인 [1, 2, 3]을 개별 요소로 펼친다.

배열 arr2의 다른 요소들과 결합되어 [4, 1, 2, 3, 5, 6]이라는 새로운 배열이 생성된다.

 

let obj1 = { a: 1, b: 2 };
let obj2 = { ...obj1, c: 3, c: 4 };
console.log(obj2);

...obj1객체의 속성들을 펼쳐서 새로운 객체 obj2에 복사한다.

최종적으로 { a: 1, b: 2, c: 4} 객체가 출력된다.

 

function funcA(p1, p2, p3) {
  console.log(p1, p2, p3);
}

funcA(...arr1);

...arr1의 요소들인 [1, 2, 3,]을 개별 인수로 펼쳐서 함수 funcA에 전달한다.

한수 funcA는 p1 = 1, p2 = 2, p3 =3 인수로 받게되고 결과적으로 1 2 3이 출력된다.

 

3. Rest 매개변수

 - Rest 매개변수는 함수 정의에서 사용되는 문법으로 함수가 전달받은 나머지 인수들을 하나의 배열로 모아주는 역할을 한다. 나머지, 나머지 매개변수

 

function funcB(one, ...rest) {
  console.log(rest);
}
funcB(...arr1);

 

funcB 함수는 one을 받고 나머지 인수들은 rest라는 배열로 모으게 되는데 one에 첫번째 인수가 할당되면 그외 나머지 인수들은 모두 rest배열에 담긴다.

 

funcB(...arr1)

 - arr1 배열의 값이 [1, 2, 3]일때 funcB(one에 1을 할당하고 나머지 2, 3을 rest배열로 받게된다.

728x90
반응형
LIST