在一段时间内阻止函数下次执行
Prevent a function from executing next time for a duration
我有一个JS函数。我想让它在第一次执行后暂停10秒,之后我想恢复它。
那么,我所做的是:
$( "#button_yes,#button_no" ).click(function()
{
if(counter)
{
console.log('Done');
$.ajax(
{
url: baseURL+"add_votes",
success: function(result)
{
counter=0;
alert(result);
setTimeout(check, 10000); //set a 10s delay
counter=1;
},
method: "POST",
data:
{
id : '1'
},
});
}
});
但如果我不能完美地工作。如果我多次单击,它将永久防止函数执行第二次。
有解决办法吗?
如何跟踪最后一次单击按钮并确保在处理下一次单击之前已经过了10s ?
var lastClicked = 0;
$( "#button_yes,#button_no" ).click(function()
{
var now = new Date();
if(now - lastClicked > 10000)
{
lastClicked = now;
console.log('Done');
$.ajax(
{
url: baseURL+"add_votes",
success: function(result)
{
alert(result);
},
method: "POST",
data:
{
id : '1'
},
});
}
});
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 如何在JavaScript中将字符串转换为函数引用
- 用嵌套函数和默认函数定义函数
- 使用 jQuery 的 .on 函数如何获取事件的原始元素
- 无法导出函数expressjs/requestjs中的变量
- 函数参数中的数据与指定变量之间的任何性能差异
- JQuery合并了keyup和focusout两个函数
- ES6构造函数返回基类的实例
- 监视函数从服务返回不起作用,但作用域函数起作用
- 我可以在json对象中添加一个函数吗
- AngularJS:我可以跳过函数参数回调吗
- 如何使jQuery插件函数可调用以供独立使用,而不在集合上操作
- JavaScript数组排序(函数)用于对表行进行排序,而不是排序
- jquery点击函数select&取消选择
- 拨打'父亲'函数形式a'儿童'ReactJS中的组件
- 第一次调用函数不会按预期工作,但下次会正常工作
- 在下次调用函数时更改函数内的变量
- 在一段时间内阻止函数下次执行
- 函数调用只工作一次,但下次不工作