프로그래밍 (Programming)/자바스크립트 (JavaScript)

[Javascript/Array] slice, splice (배열 자르기, 배열 복사, 얕은 복사)

Bbaktaeho 2020. 5. 23. 01:02
반응형

📚 slice, splice

  • 자바스크립트 Array.prototype
  • slice 는 배열을 얕은 복사 해서 새로운 배열로 반환
  • splice 는 배열의 기존 요소를 추가, 변경, 삭제해 원본 배열을 변경

📗 slice

기존 배열에서 새로운 배열로 깊은 복사

  • 배열.slice( start[,end ] )

  • 반환 타입은 배열

  • start 을 지정하지 않으면 인덱스 0 부터 시작

  • end 는 종료할 인덱스로 end 전까지 복사함

  • end 를 지정하지 않으면 배열의 길이가 됨 (길이보다 큰 수가 와도 배열의 길이)

  • 배열의 복사 1

var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];

var arrSlice = arr.slice(); // 0 부터 arr.length 전 까지 얕은 복사

console.log(arrSlice);
[ 1, 2, 3, 4, 5, 6, 7, 8, 9 ]
  • 배열의 복사 2
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];

var arrSlice1 = arr.slice(1);
var arrSlice2 = arr.slice(1, 0);
var arrSlice3 = arr.slice(1, -1);
var arrSlice4 = arr.slice(-2);

console.log(arrSlice1);
console.log(arrSlice2);
console.log(arrSlice3);
console.log(arrSlice4);
[ 2, 3, 4, 5, 6, 7, 8, 9 ]
[]
[ 2, 3, 4, 5, 6, 7, 8 ]
[ 8, 9 ]
  • 배열의 복사 3

    참조형을 요소로 가지는 배열의 경우 얕은 복사로 인해 대참사가 발생할 수 있음

var arr = [{ a: 'A', b: 'B' }, [1, 2, 3]];

var arrSlice = arr.slice(); // [{ a: 'A', b: 'B' }, [1, 2, 3]]

arr[0].a = 'AA'; // arr -> [{ a: 'AA', b: 'B' }, [1, 2, 3]] ?
arrSlice[1].push(4); // arrSlice -> [{ a: 'A', b: 'B' }, [1, 2, 3, 4]] ?

console.log(arr);
console.log(arrSlice);
[ { a: 'AA', b: 'B' }, [ 1, 2, 3, 4 ] ]
[ { a: 'AA', b: 'B' }, [ 1, 2, 3, 4 ] ]

📒 splice

배열의 기존 요소를 변경하는 메서드

  • 배열.splice(start[, deleteCount[, item1[, item2[, ...]]]])

  • 반환 타입은 배열로 제거한 요소가 있다면 반환

  • start는 배열의 변경을 시작할 인덱스

  • deleteCount는 배열에서 제거할 요소의 수, 0 이면 삭제하지 않음

  • item1, item2, item3, ... 아이템들은 배열에 추가할 요소

  • 배열에서 특정 위치의 요소 또는 요소들을 삭제

var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];

var arrSplice1 = arr.splice(1, 1); // 인덱스 1의 요소를 삭제
var arrSplice2 = arr.splice(1, 3); // 인덱스 1부터 3개를 삭제
var arrSplice3 = arr.splice(0); // 모두 삭제

console.log(arr);
console.log(arrSplice1);
console.log(arrSplice2);
console.log(arrSplice3);
[]
[ 2 ]
[ 3, 4, 5 ]
[ 1, 6, 7, 8, 9 ]
  • 배열에서 특정 위치에 요소 또는 요소들을 추가

    삭제한 요소가 없다면 빈 배열을 반환

var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];

var arrSplice1 = arr.splice(1, 0, '추가1');
var arrSplice2 = arr.splice(3, 0, '추가2', '추가3', { add: '추가4' });

console.log(arr);
console.log(arrSplice1);
console.log(arrSplice2);
[ 1, '추가1', 2, '추가2', '추가3', { add: '추가4' }, 3, 4, 5, 6, 7, 8, 9 ]
[]
[]

반응형