[javascript] JavaScript 배열 스플 라이스 및 슬라이스

차이점은 무엇이며 splice그리고 slice?

$scope.participantForms.splice(index, 1);
$scope.participantForms.slice(index, 1);



답변

splice()원래 배열을 변경하지만 slice()그렇지 않으면 둘 다 배열 객체를 반환합니다.

아래 예를 참조하십시오.

var array=[1,2,3,4,5];
console.log(array.splice(2));

이 반환 [3,4,5]됩니다. 원래 어레이 영향 의 결과로 array존재 [1,2].

var array=[1,2,3,4,5]
console.log(array.slice(2));

이 반환 [3,4,5]됩니다. 원의 배열은 영향을받지 않는 결과로 array[1,2,3,4,5].

아래는 이것을 확인하는 간단한 바이올린입니다.

//splice
var array=[1,2,3,4,5];
console.log(array.splice(2));

//slice
var array2=[1,2,3,4,5]
console.log(array2.slice(2));


console.log("----after-----");
console.log(array);
console.log(array2);


답변

스플 라이스와 슬라이스는 모두 자바 스크립트 배열 함수입니다.

스플 라이스 대 슬라이스

  1. splice () 메서드는 배열에서 제거 된 항목을 반환하고 slice () 메서드는 배열에서 선택한 요소를 새 배열 객체로 반환합니다.

  2. splice () 메서드는 원래 배열을 변경하고 slice () 메서드는 원래 배열을 변경하지 않습니다.

  3. splice () 메서드는 n 개의 인수를 사용할 수 있으며 slice () 메서드는 2 개의 인수를 사용합니다.

예제가있는 스플 라이스

인수 1 : 색인, 필수 항목을 추가 / 제거 할 위치를 지정하는 정수입니다. 음수 값을 사용하여 배열 끝에서 위치를 지정하십시오.

인수 2 : 선택 사항. 제거 할 항목 수입니다. 0으로 설정하면 항목이 제거되지 않습니다. 전달하지 않으면 제공된 색인의 모든 항목이 제거됩니다.

인수 3… n : 선택 사항. 배열에 추가 할 새 항목

var array=[1,2,3,4,5];
console.log(array.splice(2));
// shows [3, 4, 5], returned removed item(s) as a new array object.

console.log(array);
// shows [1, 2], original array altered.

var array2=[6,7,8,9,0];
console.log(array2.splice(2,1));
// shows [8]

console.log(array2.splice(2,0));
//shows [] , as no item(s) removed.

console.log(array2);
// shows [6,7,9,0]

예를 들어 슬라이스

인수 1 : 필수입니다. 선택을 시작할 위치를 지정하는 정수입니다 (첫 번째 요소의 색인은 0입니다). 배열의 끝에서 선택하려면 음수를 사용하십시오.

인수 2 : 선택 사항. 선택을 종료 할 위치를 지정하지만 포함하지 않는 정수입니다. 생략하면 시작 위치에서 배열 끝까지의 모든 요소가 선택됩니다. 배열의 끝에서 선택하려면 음수를 사용하십시오.

var array=[1,2,3,4,5]
console.log(array.slice(2));
// shows [3, 4, 5], returned selected element(s).

console.log(array.slice(-2));
// shows [4, 5], returned selected element(s).
console.log(array);
// shows [1, 2, 3, 4, 5], original array remains intact.

var array2=[6,7,8,9,0];
console.log(array2.slice(2,4));
// shows [8, 9]

console.log(array2.slice(-2,4));
// shows [9]

console.log(array2.slice(-3,-1));
// shows [8, 9]

console.log(array2);
// shows [6, 7, 8, 9, 0]


답변

슬라이스 () 메소드는 새로운 어레이 오브젝트에 배열의 일부의 사본을 돌려 준다.

$scope.participantForms.slice(index, 1);

이것은 않습니다 NOT 변경 participantForms배열을 만에서 발견 된 하나의 요소가 포함 된 새로운 배열을 반환 index원래의 배열의 위치를.

접합부 () 메소드는 기존의 요소를 제거 및 / 또는 새로운 구성 요소를 추가하여 배열의 내용을 변경한다.

$scope.participantForms.splice(index, 1);

그러면 위치 participantForms에서 한 요소가 배열에서 제거됩니다 index.

이것들은 Javascript 네이티브 함수이며 AngularJS는 그들과 관련이 없습니다.


답변

여기의 차이 기억하는 간단한 트릭 slice대이splice

var a=['j','u','r','g','e','n'];

// array.slice(startIndex, endIndex)
a.slice(2,3);
// => ["r"]

//array.splice(startIndex, deleteCount)
a.splice(2,3);
// => ["r","g","e"]

Trick to remember:

"spl" (first 3 letters of splice)두 번째 인수는 색인이 아닌 길이 여야한다는 “특정 길이”에 대해 짧게 생각하십시오.


답변

스플 라이스 – MDN 참조ECMA-262 사양

통사론
array.splice(start[, deleteCount[, item1[, item2[, ...]]]])

매개 변수

  • start: 필수. 초기 색인.
    경우 start가 취급되는 마이너스 "Math.max((array.length + start), 0)"의 단부에서 유효 사양 (아래에 제공된 예) 당 array.
  • deleteCount: 선택 사항. 제거 할 요소 수입니다 ( start제공되지 않은 경우 모두 ).
  • item1, item2, ...: 선택 사항. start인덱스 에서 배열에 추가 할 요소

반환 된 요소가있는 배열 (제거되지 않은 경우 빈 배열)

원래 배열을 돌연변이 : 예

예 :

const array = [1,2,3,4,5];

// Remove first element
console.log('Elements deleted:', array.splice(0, 1), 'mutated array:', array);
// Elements deleted: [ 1 ] mutated array: [ 2, 3, 4, 5 ]

// array = [ 2, 3, 4, 5]
// Remove last element (start -> array.length+start = 3)
console.log('Elements deleted:', array.splice(-1, 1), 'mutated array:', array);
// Elements deleted: [ 5 ] mutated array: [ 2, 3, 4 ]

MDN Splice 예제의 추가 예제


슬라이스 – MDN 참조ECMA-262 사양

구문
array.slice([begin[, end]])
매개 변수

  • begin: 선택 사항. 초기 색인 (기본값 0)
    경우 begin가 취급되는 마이너스 "Math.max((array.length + begin), 0)"의 단부에서 유효 사양 (아래에 제공된 예) 당 array.
  • end: 선택 사항. 추출을위한 마지막 인덱스 (포함하지 않음 (기본 array.length)). 경우 end가 취급되는 마이너스 "Math.max((array.length + begin),0)"의 단부에서 유효 사양 (아래에 제공된 예) 당 array.

리턴 : 추출 된 요소를 포함하는 배열.

원래 돌연변이 : 아니오

예 :

const array = [1,2,3,4,5];

// Extract first element
console.log('Elements extracted:', array.slice(0, 1), 'array:', array);
// Elements extracted: [ 1 ] array: [ 1, 2, 3, 4, 5 ]

// Extract last element (start -> array.length+start = 4)
console.log('Elements extracted:', array.slice(-1), 'array:', array);
// Elements extracted: [ 5 ] array: [ 1, 2, 3, 4, 5 ]

MDN 슬라이스 예제에서 더 많은 예제

성능 비교

각 시나리오에 따라 다른 시나리오보다 성능이 우수 할 수 있으므로이를 절대적인 사실로 간주하지 마십시오.
성능 테스트


답변

스플 라이스 및 슬라이스는 내장 Javascript 명령이며, 특히 AngularJS 명령이 아닙니다. Slice는 “end”지정자 직전까지 “start”부터 배열 요소를 반환합니다. Splice는 실제 배열을 변경하고 “시작”에서 시작하여 지정된 요소 수를 유지합니다. 구글은 이것에 관한 많은 정보를 가지고있다. 검색 만하면된다.


답변

splice()메소드는 제거 된 항목을 배열로 리턴합니다. 이 slice()메소드는 선택한 요소를 배열에서 새 배열 객체로 반환합니다.

splice()방법은 원의 배열을 변경 및 slice()방법은 원의 배열을 변경하지 않는다.

  • Splice() 메소드는 n 개의 인수를 사용할 수 있습니다.

    인수 1 : 색인, 필수

    인수 2 : 선택 사항. 제거 할 항목 수입니다. 0으로 설정하면 항목이 제거되지 않습니다. 전달하지 않으면 제공된 색인의 모든 항목이 제거됩니다.

    인수 3..n : 선택 사항. 배열에 추가 할 새 항목

  • slice() 메소드는 두 가지 인수를 취할 수 있습니다.

    인수 1 : 필수입니다. 선택을 시작할 위치를 지정하는 정수입니다 (첫 번째 요소의 색인은 0입니다). 배열의 끝에서 선택하려면 음수를 사용하십시오.

    인수 2 : 선택 사항. 선택을 종료 할 위치를 지정하는 정수입니다. 생략하면 시작 위치에서 배열 끝까지의 모든 요소가 선택됩니다. 배열의 끝에서 선택하려면 음수를 사용하십시오.