>  기사  >  웹 프론트엔드  >  javascript_javascript 기술의 setTimeout 문제에 대한 해결 방법

javascript_javascript 기술의 setTimeout 문제에 대한 해결 방법

WBOY
WBOY원래의
2016-05-16 16:49:291445검색

아마도 이와 같은 문제를 보았습니다.

코드 복사 코드는 다음과 같습니다.

name = 'out of you'
foo = function(){
this.name = 'xxoo';
}
foo.prototype.say = function(){
console.log(this.name); }
f = new foo();
f.say(); // 이 문장은 xxoo를 출력합니다.
setTimeout(f.say, 500) // 이 문장은

이것은 JavaScript의 this가 호출될 때 생성되는 함정이며 컨텍스트와도 관련이 있습니다. 해결 방법은 다음과 같습니다. 테스트하고 통화를 사용했습니다.

코드 복사 코드는 다음과 같습니다.
setTimeout.call(foo(), f .say, 500)

인터넷의 일부 솔루션

이는 js의 setTimeout 문제를 나타냅니다


JavaScript에서 Timer 사용
결국 이를 이해하는 것이 문제입니다.

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