강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

hcode님의 프로필 이미지
hcode

작성한 질문수

코어 자바스크립트

this

setTimeout 에서 this

작성

·

18

0

영상에서 setTimeout()함수 예제를 설명하실 때 setTimeout()은 this 를 별도로 처리하고 있지 않아서 전역객체로 나온다는 설명이 있는데 이 말이 setTimeout()에서 콜백함수를 별다른 처리없이 함수로써 호출하고만 있다는 뜻인가요?

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. hcode님 질문 주셔서 감사합니다.

질문하신 내용에 대해 설명드리겠습니다. setTimeout() 함수는 비동기적으로 코드를 실행하는 데 사용됩니다. 이 함수는 두 번째 인자로 전달된 시간 후에 첫 번째 인자로 전달된 콜백 함수를 호출합니다.

setTimeout()의 콜백 함수는 기본적으로 전역 객체에서 실행됩니다. 이는 setTimeout이 콜백 함수를 호출할 때 바로 함수로서 호출하기 때문입니다. this를 별도로 바인딩하지 않고 호출되기에, 콜백 함수 안에서의 this는 전역 객체(브라우저 환경에서는 window, Node.js 환경에서는 global)를 가리키게 됩니다.

따라서 setTimeout() 안의 this를 특정 객체를 가리키도록 하고 싶다면, bind, call, apply와 같은 메소드를 사용하여 원하는 객체로 this를 명시적으로 바인딩할 필요가 있습니다.

아래 링크에서 유사한 질문과 답변을 참고하실 수 있습니다:
- bind함수대신 var self = this로 바꾸어서 만들어보려하는데요.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

hcode님의 프로필 이미지
hcode

작성한 질문수

질문하기