回调函数传参与防抖动处理 《二》

上一篇讲了回调函数,现在谈谈防抖动处理

思路

    1:当点击按钮的时候,用转圈的方式来显示,并且此时不能够再次点击,这种方式交互性比较好,个人还是比较推荐的,实现方式也很简单,网络上很多,就不赘述了

    2:

    3:当点击的时候,某一时间段内多次点击,只有一次生效。这种就是我在这个项目中所用到的方式,具体实现方式如下

           1:创建一个js文件,写一个防抖动处理的函数

let timeout;
let wait=1000;
let immediate = false;
// export function Debounce(func, wait=1000, immediate = false) {
export function Debounce(func, ...arges) {
// 清除定时器
if (timeout !== null) clearTimeout(timeout);

    // 立即执行,此类情况一般用不到
    if (immediate) {
        var callNow = !timeout;

        timeout = setTimeout(function() {
        timeout = null;

        }, wait);
        if (callNow) typeof func === 'function' && func(...arges);
    } else {
        // 设置定时器,当最后一次操作后,timeout不会再被清除,所以在延时wait毫秒后执行func回调方法
        timeout = setTimeout(function() {
        typeof func === 'function' && func(...arges);

        }, wait);
    }
}

              2:在main.js中进行全局注册

import {Debounce} from './utils/debounce'
/* 注册防抖动处理 */
Vue.prototype.$Debounce = Debounce;

              3:使用

<Button type="default" size="small" style="margin: 5px" @click="$Debounce(audit,row.infoId,1)">审核通过</Button>

 

总结
            1:可能有朋友会问,为什么不在debounce.js中就进行注册呢,要多此一举在main.js中引入,然后再进行全局注册?

                    这是因为我在使用过程中发现,当ctrl+r的时候,如果在debounce.js进行注册,这个时候就会报错,说是没有这个方法,所以我怀疑是一个加载顺序或者说速度的问题,我在页面中使用了,但是这个时候还没有全局注册完成呢,所以就报这个错了,当然这个只是我的猜测,我也不敢肯定,因为在列表页面就算CTRL+R也不会这样,只有在新建页面会这样,可能是我在新建页面引入了其他的东西导致的吧,谁知道呢,事情太多,现在没时间去追究

这个问题花了我一个多小时,特此记录!

暂时先这样啦,很晚了,睡觉。。。
   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值