由于用户的网络环境等各种原因,防止按钮重复点击,表单重复提交等都是减少bug发生,降低服务器压力等相当有效的方法。下面来聊聊通过模拟我们在操作系统里类似加锁的思想来防止重复点击。
目录
思路
- 声明一个锁(布尔值),用来标识按钮,变量是否被锁上
- 当按钮按下后,把布尔值设置为false,即标记为已锁上
- 设置一个延时函数setTimeout(),等待一段时间后再把这个锁归还,设置布尔值为true
- 显然我们的按钮点击事件一开始就应该判断锁是否被锁上,是则直接结束。否则才能正常执行
示例
- HTML / JS
<div style="width:100%;display:flex;justify-content: center;background:#66ccff;border-radius:10px;border 1px solid #66ccff;">
<button onclick="btn_click()" style="border-radius:10px;">
点死我
</button>
</div>
<script>
//锁变量
let lock = true;
//按钮点击执行函数
function btn_click() {
if(lock == false) {
return;
}
//加锁
lock = false;
//执行按钮点击本应执行的事情
alert("点了一下我捏");
//限制间隔5000毫秒(即5秒)只能执行一次
setTimeout(function(){
//解锁
lock = true;
},5000);
}
</script>
- 效果(每隔5秒只会执行一次按钮点击应该执行的事情):
结语
- 本文的例子思路和实现都是相当简单的,但确是很实用的方法。
- 另外,从这个思路出发,还能解决一些类似的问题,比如:
- 音乐进度条的拖动。由于拖动的报告率太高,导致拖动过程界面卡顿,音乐的播放也很卡顿,那就可以用这个思路,每一段时间内只对应响应一次。
- 降低输入框的响应。
- 后续我们再聊聊上面这些例子的解决方法实现。他们本质都是这个模拟加锁的思路,但可能有些需要一些细节上不同的处理。
lipitor atorvastatin calcium
dark web market list dark web search engines
deep web markets darkmarket list
dark web links deep web sites
darkmarket list tor marketplace
prednisone 5 mg brand name
darknet websites darkweb marketplace
dark web site tor market links
augmentin 625 in usa
dark web link darknet links
dark website dark market url
dark web markets tor market url
buy azithromycin india
deep web drug markets darknet market links
dark market the dark internet
darknet market links best darknet markets
bitcoin dark web free dark web
deep dark web darknet drug market
tor markets 2023 dark markets 2023
dark market onion dark web sites
dark market onion dark web market links
tor markets 2023 deep web drug store
dark web search engines blackweb
tor markets dark web websites
tor marketplace dark web access
advair diskus generic price
dark internet how to get on dark web
drug markets dark web dark web access
tor markets dark web websites
dark web sites deep web drug url
dark web drug marketplace darknet marketplace
zanaflex 4mg
darkmarket url dark web sites
dark web sites links tor markets links
darknet search engine drug markets onion
buy diflucan yeast infection
deep web sites darknet drug store
tor markets 2023 darknet market list
darknet seiten darknet drug store
black internet bitcoin dark web
dark internet dark web market list
darkmarket link dark web search engine
darkmarket darknet market lists
deep web sites tor markets links
darknet market lists how to access dark web
tor darknet darknet market links
darknet sites darknet markets
synthroid 0.15
darkmarket 2023 deep web drug store
dark websites dark web sites links