click1(){
if(this.orderSuccess){
click()
}}
click(){
clearTimeout(this.timeOut)
this.orderSuccess = false
this.timeOut = setTimeout(()=>{
this.orderSuccess = true
},5000)
}
请问vue里这样的节流方式有什么弊端?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
关注 你这个定时器完全没必要写在data里,不然vue还得对你这个数据拦截进行响应式处理,消耗性能
直接在click1方法里声明一个定时器就好了,click方法使用了click1的数据形成了闭包
click1(){
let timer = null
if(this.orderSuccess){
click(timer )
}}click(timer ){
clearTimeout(this.timeOut)
this.orderSuccess = false
timer = setTimeout(()=>{
this.orderSuccess = true
},5000)
}如有帮助,望采纳^.^ 谢谢啦
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥20 测距传感器数据手册i2c
- ¥15 RPA正常跑,cmd输入cookies跑不出来
- ¥15 求帮我调试一下freefem代码
- ¥15 matlab代码解决,怎么运行
- ¥15 R语言Rstudio突然无法启动
- ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
- ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
- ¥15 用windows做服务的同志有吗
- ¥60 求一个简单的网页(标签-安全|关键词-上传)
- ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法