当值改变时,setTimeout函数不起作用
setTimeout function not working with value change
setTimeout函数未按预期工作。下面是我的代码:
$(document).delegate('.pur','click', function(e){
var productid = $(this).attr('id');
var quantity = $('#qua').val();
if(quantity>0){
this.value='Adding';
}
else{
this.value='Min 100';
setTimeout(function(){this.value='Buy now'}, 3000);
}
});
上面的代码根本不起作用,它在3秒后没有像预期的那样改变值。有什么瑕疵吗?有人能帮忙找出它的毛病吗?
作用域问题
在setTimeout内,"this"所指的对象与setTimeout外所指的对象不同。
像这样修改
$(document).delegate('.pur','click', function(e){
var productid = $(this).attr('id');
var quantity = $('#qua').val();
if(quantity>0){
this.value='Adding';
}
else{
this.value='Min 100';
var that = this; // hold a reference to "this" as "that"
setTimeout(function(){that.value='Buy now'}, 3000); // use "that" instead of "this"
}
});
匿名函数中对"this"的引用没有指向任何东西。您可以这样更改它(即,self
是匿名函数可见性范围内的变量):
this.value='Min 100';
var self = this;
setTimeout(function(){self.value='Buy now'}, 3000);
这应该也能奏效
setTimeout(function() { this.value = 'Buy now'; }.bind(this), 3000)
相关文章:
- setTimeout函数能否在其前面的代码执行之前激发
- JS:setTimeout函数的UI计数
- Jasmine:测试setTimeout函数会抛出一个错误
- Javascript/Jquery setTimeout 函数不适用于长 html
- 如何让 setTimeout 函数运行,然后停止使用循环
- 有没有办法覆盖 setTimeout 函数,使其使用微秒而不是毫秒
- setTimeout函数的精确计时
- Javascript-为什么不是't此setTimeout函数正在工作
- 阻止页面重新加载时的setTimeout函数
- 2 setTimeout函数第一个清除第二个javascript
- 如何在 setInterval/setTimeout 函数中按名称调用函数
- Javascript SetTimeOut函数不知怎么不起作用
- Javascript setTimeOut 函数与 .net 中 Windows 应用程序的计时器不匹配
- Javascript setTimeout 函数保持运行
- 当 ajax 返回 1 时如何删除 setTimeout 函数
- setTimeout 函数比它应该的更快
- Javascript:我的setTimeout函数由于第三方而不起作用
- 如何或在哪里将javascript settimeout函数添加到CSS垂直下拉菜单
- 在 javascript 对象中使用方法的值以在 setTimeout 函数中使用
- 如何阻止此 setTimeout 函数运行