>웹 프론트엔드 >JS 튜토리얼 >Array.prototype.slice.call은 인수를 배열로 어떻게 조작합니까?

Array.prototype.slice.call은 인수를 배열로 어떻게 조작합니까?

DDD
DDD원래의
2024-10-21 21:57:02556검색

How Does Array.prototype.slice.call Manipulate Arguments into an Array?

Array.prototype.slice.call: 인수 조작의 비밀 풀기

Array.prototype.slice.call 메소드는 강력한 인수를 적절한 배열로 변환할 수 있는 도구입니다. 그런데 뒤에서는 어떻게 작동하나요?

메서드 호출 및 "this" 키워드

객체에 대해 메소드를 호출하면 객체 자체가 값이 됩니다. 메소드 내의 this 키워드. 예를 들어, 다음 줄에서:

[1,2,3].slice()

[1,2,3] 배열은 슬라이스 메서드에서 this의 값이 됩니다.

"배열로서의 인수 -Like Object"

함수 인수를 나타내는 인수 개체에는 배열과 유사한 여러 속성이 있습니다.

  • 숫자 .length 속성
  • 숫자 인덱스 속성(예: 인수[0], 인수[1] 등).

The Magic of Array.prototype.slice.call

Array.prototype.slice.call 메소드를 사용하면 함수의 this 값을 수동으로 설정할 수 있습니다. 이것을 인수 객체로 설정함으로써 본질적으로 슬라이스 메소드가 배열에서 작동하고 있다고 믿도록 속입니다.

이는 슬라이스 메소드가 이것이 배열이라는 가정하에 작동하기 때문입니다. 숫자 .length 속성과 숫자 인덱스 속성 집합이 있는 한, Slice에서는 이를 배열로 처리합니다.

예: 인수를 배열로 변환

다음 코드를 고려하세요.

var myArguments = (1, 2, 3, 4, 5);
var myArray = Array.prototype.slice.call(myArguments);

console.log(myArray);

출력:

[1, 2, 3, 4, 5]

이 예에서 슬라이스 메소드는 myArguments 인수 객체를 적절한 배열로 변환한 다음 console.

결론

this 키워드의 역할, 유사 배열 객체, 슬라이스 메소드의 가정을 이해함으로써 Array.prototype의 강력한 기능을 활용할 수 있습니다. .slice.call은 인수를 조작하고 재사용 가능한 배열 처리 코드를 생성합니다.

위 내용은 Array.prototype.slice.call은 인수를 배열로 어떻게 조작합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.