> 웹 프론트엔드 > JS 튜토리얼 > 중첩된 JavaScript 함수에서 \'this\' 포인터는 어떻게 해결됩니까?

중첩된 JavaScript 함수에서 \'this\' 포인터는 어떻게 해결됩니까?

Barbara Streisand
풀어 주다: 2024-10-19 06:43:30
원래의
660명이 탐색했습니다.

How Does the

중첩된 JavaScript 함수의 "this" 포인터 동작

이 질문은 중첩된 함수로 작업할 때 "this" 포인터가 동작하는 방식을 이해하는 것과 관련이 있습니다. 자바스크립트에서. 함수를 중첩할 때 각 범위 내에서 "this" 포인터가 어떻게 해결되는지 고려하는 것이 중요합니다.

제공된 샘플 코드에서 "this" 포인터는 호출 시 중첩된 함수 "doSomeEffects()"에서 발견됩니다. "std_obj" 개체의 "displayMe()" 함수 내에서. 그러나 놀랍게도 "this" 포인터는 예상대로 "std_obj"가 아닌 "window" 개체를 참조합니다.

이는 JavaScript의 "this" 포인터가 호출 컨텍스트에 동적으로 바인딩되어 있기 때문에 발생합니다. 함수 선언에 의해 정적으로 결정됩니다. 대신 "this" 값은 함수가 호출될 때 결정됩니다.

중첩 함수가 호출되면 "this" 포인터가 명시적으로 설정되지 않으며 JavaScript의 기본 동작이 대신됩니다. 기본적으로 "this" 포인터는 명시적인 컨텍스트 없이 호출될 때 전역 "window" 개체를 참조합니다.

이 문제를 해결하려면 중첩 함수에 대한 컨텍스트를 명시적으로 설정해야 합니다. 이는 "call()" 또는 "apply()" 메소드를 사용하여 달성할 수 있습니다. "doSomeEffects.call(this)"을 호출하면 "this" 포인터를 "std_obj" 개체에 수동으로 바인딩할 수 있습니다.

"this" 포인터가 명시적으로 설정되면 중첩 함수는 다음의 속성에 액세스할 수 있습니다. 호출 개체가 올바르게 작동합니다. 이 경우 "doSomeEffects"의 "this" 포인터는 "std_obj" 개체를 참조하므로 중첩된 함수가 의도한 대로 작동할 수 있습니다.

위 내용은 중첩된 JavaScript 함수에서 \'this\' 포인터는 어떻게 해결됩니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿