我是靠谱客的博主 羞涩魔镜,最近开发中收集的这篇文章主要介绍javascript中setTimeout的问题解决方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

看到一个问题,大概是这个样子得。

复制代码 代码如下:

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); // 这句会输出out of you

这是个坑,javascript的this是在调用的时候产生的,还跟上下文有关。这么解决呢。我测试了一下,用了call。
复制代码 代码如下:

setTimeout.call(foo(), f.say, 500)

网上的一些解决方法

js中setTimeout的this指向问题

JavaScript中使用Timer

最后其实还是对this得理解问题。

哪天搞得明白点了再继续写

最后

以上就是羞涩魔镜为你收集整理的javascript中setTimeout的问题解决方法的全部内容,希望文章能够帮你解决javascript中setTimeout的问题解决方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(121)

评论列表共有 0 条评论

立即
投稿
返回
顶部