您的位置:首页 > 健康 > 美食 > vue封装全局的防抖节流函数

vue封装全局的防抖节流函数

2025/1/8 13:06:33 来源:https://blog.csdn.net/m0_56104994/article/details/139632469  浏览:    关键词:vue封装全局的防抖节流函数

1.在入口文件main.js中:

//防抖函数
export let debounce = (() => {let instances = []return function (fun, delay = 300) {//项目中,多个地方用到防抖,进行判断,每次调用全局的防抖函数,是否是同一块代码const stackLines = new Error().stack.split('\n');let callerLine = stackLines[2];//判断数组中是否有了let index = instances.findIndex(item => {return item.callerLine == callerLine})if (index < 0) {//没有的话,直接新增一个instances.push({ callerLine, fun, delay, timer: null })index = instances.length - 1} else {//有了的话,直接将传递的逻辑函数赋值进去instances[index].fun = fun}//找到数据中对应的对象let instance = instances[index]let ctx = thislet args = arguments//有时间间隔器,则清除if (instance.timer) {clearTimeout(instance.timer)}//进行其他逻辑instance.timer = setTimeout(() => {instance.timer = nullinstance.fun.apply(ctx, args)}, instance.delay)}
})()//节流函数
export let throttle = (() => {let instances = []return function (fun, delay = 300) {const stackLines = new Error().stack.split('\n');let callerLine = stackLines[2];let index = instances.findIndex(item => {return item.callerLine == callerLine})if (index < 0) {instances.push({ callerLine, fun, delay, timeout: null })index = instances.length - 1} else {instances[index].fun = fun}let instance = instances[index]let args = arguments;//注意如果要传参的话 这句不能省略if (!instance.timeout) {instance.timeout = setTimeout(() => {instance.timeout = null;instance.fun.apply(this, args)}, instance.delay)}}
})()Vue.prototype.$debounce = debounce;
Vue.prototype.$throttle = throttle;

2.页面中使用:

<div id="watch-example"><p>问一个是否的问题:<input v-model="question2"></p><p>{{ answer2 }}</p></div>
data() {return {question2: '',answer2: '请输入问题,否则我无法回答你!'};},

 

watch: {question2: function (newQuestion, oldQuestion) {this.answer2 = '请等待!';this.$debounce(this.getAnswer2, 1000);}},

 

getAnswer2: function() {if (this.question.indexOf('?') === -1) {this.answer2 = '请输入疑问句!';return;}else{this.answer2 = '请稍后...';setTimeout(() => {this.answer2 = '章总';}, 1000)}}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com