vue函数防抖和节流
2024-08-30 02:58:14
Vue函数防抖和节流https://zhuanlan.zhihu.com/p/72363385
<template>
<div>
<input type='text' v-model='value' @keydown = "hangleChange">
</div>
</template> <script>
function debounce(func, wait=1000){
let timeout;
return function(event){
clearTimeout(timeout)
timeout = setTimeout(()=>{
func.call(this, event)
},wait)
}
}
export default{
name:'',
data(){
return{
value:''
}
},
methods:{
hangleChange:debounce(function(e){
console.log(this.value)
})
}
}
</script>
节流 <template>
<div class="scroll" ref="previewText" @scroll.passive="fnScroll">
</template>
<script>
export default{
name:'globalHospot',
data(){
return{
count:0,
fnScroll:() =>{}
}
},
methods: {
fnHandleScroll (e) {
console.log('scroll触发了:' + this.count++, new Date())
},
fnThrottle(fn, delay, atleast){ //节流函数
let timer = null;
let previous = null;
return function(){
let now = +new Date()
if(!previous) previous = now;
if(atleast && now - previous > atleast){
fn();
previous = now;
clearTimeout(timer)
}else{
clearTimeout(timer)
timer = setTimeout(()=>{
fn();
previous = null
},delay)
}
}
}
},
created(){
this.fnScroll = this.fnThrottle(this.fnHandleScroll, 1000) //刚创建时执行
},
}
</script>
最新文章
- Redis模式匹配删除key
- Git ——分布式版本控制系统
- 使用Javascript监控前端相关数据
- 什么时候使用CountDownLatch
- 地理围栏算法解析(Geo-fencing)
- 【MySQL】MySQL索引背后的之使用策略及优化【转】
- C#中的多态现象
- HDU 1598 find the most comfortable road (MST)
- fil_space_create
- yum命令学习
- 中国天气网接口返回json格式分析及接口(XML、图片接口)说明
- SRM 500(2-1000pt)
- FFT算法的物理意义
- Docker私有仓库3
- js详解之作用域-实例
- OSX MacVim + vim-lldb配置和使用心得
- java1.8十大新特性详解
- 【Spring源码分析系列】ApplicationContext 相关接口架构分析
- 【CH4201】楼兰图腾
- Texas Instruments matrix-gui-2.0 hacking -- json.txt
热门文章
- 开发工具Intellij IDEA:常用快捷键
- VS2015编译问题:模块对于 SAFESEH 映像是不安全的
- sass、less中的scoped属性
- 所有input输入完成后,改变按钮颜色
- 洛谷P3373 【模板】线段树 2 &;&; P2023 [AHOI2009]维护序列——题解
- 如何在Ecplise调试之后恢复原来的界面
- EasyUI combotree 设置节点折叠和叶子节点循环展开的BUG
- 北风设计模式课程---里氏替换原则(Liskov Substitution Principle)
- POJ2395 Out of Hay(求最小生成树中最大的边权,Kruskal)
- 设计模式-Runoob:设计模式简介