javascript中setTimeout的问题解决方法_javascript技巧
程序员文章站
2022-04-14 23:08:47
...
看到一个问题,大概是这个样子得。
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得理解问题。
哪天搞得明白点了再继续写
复制代码 代码如下:
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在myeclipse中报错的解决方法_javascript技巧
-
js中settimeout方法加参数_javascript技巧
-
JavaScript中需要掌握的技巧
-
JavaScript中的apply()方法和call()方法使用介绍_javascript技巧
-
JavaScript中全局变量、函数内变量以及常量表达式的效率测试_javascript技巧
-
javascript中的array数组使用技巧_基础知识
-
Javascript-Mozilla和IE中的一个函数直接量的问题分析_javascript技巧
-
JavaScript开发toggle()隐藏问题的解决方法
-
深入理解Javascript中this的作用域_javascript技巧
-
Javascript中的相等与不等运算_javascript技巧