이 기사는 JavaScript 변수 할당 및 돌연변이 안내서를 따르고 돌연변이 배열 방법에 의해 가져온 문제와 솔루션에 대해 논의합니다. 많은 JavaScript 배열 메소드는 원래 배열을 직접 수정하여 대규모 응용 프로그램에서 쉽게 추적하기 어려운 버그로 이어질 수 있습니다. 그러나 모든 방법이 이와 같은 것은 아닙니다. ,
및 Array.prototype.slice()
와 같은 방법은 새 배열을 반환합니다. 예상치 못한 돌연변이를 피하기 위해 원래 배열을 수정하는 대신 새로운 배열 객체를 반환하는 고유 한 불변 어레이 방법을 작성할 수 있습니다. 이 기사에서는 , Array.prototype.concat()
, , Array.prototype.map()
, Array.prototype.filter(), pop
및 와 같은 불변의 메소드 버전을 다룹니다. 불변의 배열 방법을 사용하면 부작용으로 인한 버그를 피하기 위해 더 명확하고 쉽게 코드를 유지할 수 있습니다. push
JavaScript의 배열 돌연변이 shift
unshift
reverse
splice
그러나 메소드도 배열을 수정했는데, 이는 우리가 원하는 결과가 아닙니다.
const numbers = [1,2,3]; const countdown = numbers.reverse();
<<> 외에도 numbers
외에도이 돌연변이를 일으키는 다른 배열 방법이 많이 있습니다.
countdown
numbers
<<>
countdown // [3, 2, 1]
reverse()
<<> numbers
numbers // [3, 2, 1]
<<> Array.prototype.push()
countdown
<<> numbers
countdown.push(0) countdown // [3, 2, 1, 0] numbers // [3, 2, 1, 0]
대조적으로, 일부 방법은 원래 배열을 수정하지 않지만 새 배열을 반환합니다.
Array.prototype.slice()
Array.prototype.concat()
<<> Array.prototype.map()
Array.prototype.filter()
map()
const numbers = [1,2,3]; const countdown = numbers.reverse();
<<> numbers
countdown // [3, 2, 1]
함수를 작성하여 시작하겠습니다.
를 사용하여 배열의 사본을 반환하지만 마지막 항목을 제거합니다. 두 번째 매개 변수 -1은 "정지 슬라이스, 끝 이전의 1 위치"를 의미합니다. 다음 예제에서 어떻게 작동하는지 알 수 있습니다. <<>
다음으로, 새 배열을 반환 할
함수를 만들지 만 끝에 새 요소를 추가하겠습니다.
Array.prototype
이것은 확장 연산자를 사용하여 배열의 사본을 만듭니다. 그런 다음 제공된 값을 새 배열의 끝에 두 번째 매개 변수로 추가합니다. 예는 다음과 같습니다.
<<> 및 pop
및 pop
유사하게 쓸 수 있습니다.
Array.prototype.pop()
numbers // [3, 2, 1]
Array.prototype.slice()
우리의 <🎜 🎜> 메소드는 새 배열을 반환하고 배열의 시작 부분에 새 값을 추가합니다 : <🎜 🎜>
countdown.push(0) countdown // [3, 2, 1, 0] numbers // [3, 2, 1, 0]
<<> push
메소드에 대한 대안을 쓰려고합시다. 원래 배열을 수정하는 대신 역순으로 배열 된 배열의 사본을 반환합니다.
Array.prototype.reverse()
이 방법은 여전히
const numbers = [1,2,3]; const countdown = numbers.reverse();
<<> Array.prototype.reverse()
countdown // [3, 2, 1]
를 처리합시다. 이것은 매우 일반적인 기능이므로 기능을 완전히 다시 작성하지는 않습니다 (흥미로운 연습이지만). 대신 의 두 가지 주요 용도에 중점을 둘 것입니다 : 배열에서 항목을 삭제하고 항목을 배열로 삽입합니다. splice
<<> 배열 항목 <🎜 🎜>
Array.prototype.splice()
이것은 slice
를 사용하여 배열을 반으로 자릅니다. 삭제하려는 항목의 양쪽 측면. 첫 번째 슬라이스는 새 배열을 반환하여 원래 배열의 요소를 매개 변수 인덱스로 지정할 때까지 복사합니다. 두 번째 슬라이스는 삭제하려는 요소가 포함 된 배열을 원래 배열의 끝까지 반환합니다. 그런 다음 확장 연산자를 사용하여 모두 새 배열에 넣습니다. 아래의
<<> 배열 항목을 추가하십시오 <🎜 🎜> <'s> 마지막으로, 새 배열을 반환하고 특정 인덱스에 새 값을 삽입하는 함수를 작성해 봅시다.
numbers // [3, 2, 1]
JavaScript에서 불변의 배열 메소드를 만들고 사용하는 것에 대한 FAQS
메소드가 포함됩니다.
방법을 사용하는 것입니다.이 방법은 객체에 새로운 특성을 추가하지 않고 기존 특성의 제거를 방지하며 기존 속성의 열거, 구성 가능성 또는 서면 성을 방지하는 것입니다.
javaScript의 메소드는 무엇입니까?
<,>이 예에서 <🎜 🎜> 메소드는 <🎜 🎜> 및 메소드는 제공된 기능에 의해 구현 된 테스트의 모든 요소를 포함하는 새로운 배열을 만듭니다. 다음은 사용 방법의 예입니다.
위 내용은 불변의 배열 방법 : 클리너 JavaScript 코드를 작성하십시오의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!Array.prototype.slice()
<,>이 기사에서는 원래 배열을 언어의 일부로 수정하는 배열 메소드를 수정하여 JavaScript가 생명을 어렵게 만드는 방법을 조사합니다. 그런 다음 이러한 기능을 대체하기 위해 우리 자신의 불변의 배열 방법을 작성했습니다. food
,
및 메소드는 제공된 기능에 의해 구현 된 테스트의 모든 요소를 포함하는 새로운 배열을 만듭니다. <🎜 🎜> 메소드는 어큐뮬레이터의 각 요소에 함수를 적용하고 배열을 단일 출력 값으로 줄입니다.
메소드는 둘 이상의 배열을 병합하고 새 배열을 반환하는 데 사용됩니다. ,
및 <🎜🎜>). 또 다른 접근법은 map()
filter()
reduce()
예, JavaScript의 다른 데이터 유형과 함께 불변 어레이를 사용할 수 있습니다. 불변의 개념은 배열뿐만 아니라 모든 데이터 유형에 적용됩니다. 예를 들어, 문자열, 숫자, 객체 등으로 불변의 방법을 사용할 수 있습니다. 이를 통해 코드를 더 명확하고 쉽게 작성하는 데 도움이 될 수 있습니다.
메소드를 사용하는 방법은 무엇입니까?
<,>이 예에서
<<> JavaScript의 reduce()
메소드는 배열의 모든 요소의 합을 계산합니다. reduce()
const numbers = [1,2,3];
const countdown = numbers.reverse();
reduce()
를 새로운 배열 <🎜 🎜 🎜>로 병합합니다. 메소드를 사용하는 방법은 무엇입니까?
javaScript의 concat()
concat()
<,>이 예에서 countdown // [3, 2, 1]