>웹 프론트엔드 >JS 튜토리얼 >`this`는 언제 JavaScript에 전달된 인수를 참조합니까?

`this`는 언제 JavaScript에 전달된 인수를 참조합니까?

DDD
DDD원래의
2024-11-04 04:59:02455검색

When does `this` refer to the argument passed in JavaScript?

이것은 언제 전달된 인수를 참조합니까?

JavaScript에서 this의 값은 함수가 호출되는 방식에 따라 결정됩니다. 이것이 함수에 전달된 인수를 참조하는 몇 가지 시나리오가 있습니다:

1. 메소드 호출

점 연산자를 사용하여 객체의 메소드(예: obj.method())를 호출할 때 객체 인스턴스(obj) 자체를 참조합니다. 귀하의 예에서 obj.prepareRandomFunction()이 호출되면 prepareRandomFunction 메소드 내부의 이는 obj를 참조합니다.

2. .bind() 사용

.bind() 메서드는 함수를 가져와서 호출 시 this 값이 첫 번째 인수로 제공된 값으로 설정된 새 함수를 반환합니다. 귀하의 예에서 this.sumData.bind(this)는 이것을 obj에 바인딩하는 새로운 함수를 생성합니다. 이 바인딩된 함수와 함께 randomFunction이 호출되면, 내부의 이 randomFunction은 obj를 참조합니다.

혼란 방지

혼란을 방지하고 이것이 의도한 객체를 참조하는지 확인하려면 명시적으로 다음을 수행하는 것이 좋습니다. 메서드 콜백을 다른 함수에 전달할 때 .bind()를 사용하여 this 컨텍스트를 바인딩합니다. 이렇게 하면 콜백 함수 내부의 값이 올바른지 확인할 수 있습니다.

위 내용은 `this`는 언제 JavaScript에 전달된 인수를 참조합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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