Array.prototype.slice.call의 내부 작동 방식 살펴보기(인수)
Array.prototype.slice의 동작 이해. call(arguments)에는 인수를 실제 배열로 변환하는 표면 수준 사용을 넘어서는 심층적인 탐색이 필요합니다.
일반적으로 배열에서 Slice()가 직접 호출되면 해당 요소를 반복합니다. 정렬. 그러나 .call() 및 .apply()를 사용하면 함수 내에서 this 값을 수동으로 정의할 수 있는 고유한 기회가 제공됩니다.
Array.prototype.slice.call(인수)의 경우 배열 숫자형 .length 및 인덱스 속성을 갖는 유사 객체는 다음과 같이 대체됩니다. 이 대체는 Slice()가 실제 배열을 처리한다고 가정하여 정상적인 작업을 용이하게 합니다.
고유 배열 속성이 없는 일반 개체가 .call()을 사용하여 다음과 같이 설정되는 다음 예를 생각해 보세요.
var my_object = { '0': 'zero', '1': 'one', '2': 'two', '3': 'three', '4': 'four', length: 5 }; var sliced = Array.prototype.slice.call( my_object, 3 );
놀랍게도 Slice()는 예상대로 작동하여 원하는 결과를 얻습니다.
['three','four'];
Array에서 인수 객체가 this에 대한 값으로 전달될 때 동일한 메커니즘이 적용됩니다. 프로토타입.슬라이스.콜(인수). 인수에는 .length 속성과 숫자 인덱스 배열이 있으므로, Slice()는 마치 실제 배열에서 작동하는 것처럼 진행되어 일관되고 예측 가능한 결과를 제공합니다.
위 내용은 Array.prototype.slice.call(arguments)은 인수를 배열로 어떻게 변환합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!