webbbbbbb2 2021-12-06 10:13 采纳率: 50%
浏览 47
已结题

请问vue里这样的节流方式有什么弊端?

click1(){
if(this.orderSuccess){
  click()
}}

click(){
       clearTimeout(this.timeOut)
      this.orderSuccess = false
      this.timeOut = setTimeout(()=>{
         this.orderSuccess = true
      },5000)
}
  • 写回答

3条回答 默认 最新

  • 前端阿彬 前端领域新星创作者 2021-12-06 11:21
    关注

    你这个定时器完全没必要写在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)
    }

    如有帮助,望采纳^.^ 谢谢啦

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 12月14日
  • 已采纳回答 12月6日
  • 创建了问题 12月6日