通过实例讲解JS如何防抖动


Posted in Javascript onJune 15, 2019

前言

这道题目经常与事件触发器同时存在,为了考察面试者在一些具体业务流程上(信息流,搜索框输入查询)等,能否综合的考虑实现思路。

题目

在某些信息列表中一般采用瀑布流,滚动一屏时加载相应的数据,请思考如何避免连续下拉时而产生的问题(可能是页面崩溃,也可能是巨卡无比)。

一般情况下,如果碰到这样的面试题,防抖动机制,就能很好的解决,这方面最早的应用实践还是Twitter,开发者写了一篇博客,详细的阐述了如何解决这样的问题。那么,说到防抖动,其核心内涵在于延迟处理,也就是将一系列的事件处理程序全部延迟,保障推送进来的第一次事件处理。

event.on('scroll', function(e){ 
var fun; 
return function(){ 
if(fun) clearTimeout(fun);
fun = setTimeout(function(){ 
// console.log('1')
},500);
}
}());

这是最常见的一种方式,如果scroll的次数较多时,可以先将真实的函数放置在定时器中。

接下来我们将它抽象一下:

function de(something,delay){ 
var fun; 
return function(){ 
if(fun) clearTimeout(fun);
fun = setTimeout(function(){ 
something();
},delay);
}
}
function scrollToList(){
}
event.on('scroll', de(scrollToList,1000))
event.on('scroll', de(scrollToList,2000))

显然这是一个弱爆了的处理,那有没有更好的方式呢?有,比如节流。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JSON 编辑器实现代码
Dec 06 Javascript
jQuery图片播放8款精美插件分享
Feb 17 Javascript
实例讲解JQuery中this和$(this)区别
Dec 08 Javascript
CascadeView级联组件实现思路详解(分离思想和单链表)
Apr 12 Javascript
JCrop+ajaxUpload 图像切割上传的实例代码
Jul 20 Javascript
详解堆的javascript实现方法
Nov 29 Javascript
jQuery DOM节点的遍历方法小结
Aug 15 jQuery
vue 项目常用加载器及配置详解
Jan 22 Javascript
通过封装scroll.js 获取滚动条的值
Jul 13 Javascript
Vue.Draggable拖拽功能的配置使用方法
Jul 29 Javascript
vue 组件简介
Jul 31 Javascript
使用webpack和rollup打包组件库的方法
Feb 25 Javascript
js笔试题-接收get请求参数
Jun 15 #Javascript
深入了解JavaScript 的 WebAssembly
Jun 15 #Javascript
通过实例了解js函数中参数的传递
Jun 15 #Javascript
RxJS的入门指引和初步应用
Jun 15 #Javascript
js中let能否完全替代IIFE
Jun 15 #Javascript
回顾Javascript React基础
Jun 15 #Javascript
详解微信小程序胶囊按钮返回|首页自定义导航栏功能
Jun 14 #Javascript
You might like
CPU步进是什么意思?i3-9100F B0步进和U0步进区别知识科普
2020/03/17 数码科技
Linux下进行MYSQL编程时插入中文乱码的解决方案
2007/03/15 PHP
php 无限级数据JSON格式及JS解析
2010/07/17 PHP
Code:findPosX 和 findPosY
2006/12/20 Javascript
JavaScript的目的分析
2007/01/05 Javascript
编写js扩展方法判断一个数组中是否包含某个元素
2013/11/08 Javascript
JQuery实现动态添加删除评论的方法
2015/05/18 Javascript
JS中递归函数
2016/06/17 Javascript
用JS实现图片轮播效果代码(一)
2016/06/26 Javascript
微信小程序 animation API详解及实例代码
2016/10/08 Javascript
详解Js模板引擎(TrimPath)
2016/11/22 Javascript
彻底揭秘keep-alive原理(小结)
2019/05/05 Javascript
JS实现可切换图片的幻灯切换效果示例
2019/05/24 Javascript
Vue如何基于es6导入外部js文件
2020/05/15 Javascript
微信小程序实现转盘抽奖
2020/09/21 Javascript
Python正则表达式匹配ip地址实例
2014/10/09 Python
python中threading超线程用法实例分析
2015/05/16 Python
python中函数默认值使用注意点详解
2016/06/01 Python
用python写个自动SSH登录远程服务器的小工具(实例)
2017/06/17 Python
Python 中的lambda函数介绍
2018/10/10 Python
Python实现操纵控制windows注册表的方法分析
2019/05/24 Python
Python类中的魔法方法之 __slots__原理解析
2019/08/26 Python
python Django框架实现web端分页呈现数据
2019/10/31 Python
详解Python中字符串前“b”,“r”,“u”,“f”的作用
2019/12/18 Python
Python生成器常见问题及解决方案
2020/03/21 Python
TensorFlow-gpu和opencv安装详细教程
2020/06/30 Python
canvas仿写贝塞尔曲线的示例代码
2017/12/29 HTML / CSS
蒂芙尼澳大利亚官方网站:Tiffany&Co. Australia
2017/08/27 全球购物
黄色火烈鸟:De Gele Flamingo
2019/03/18 全球购物
素食餐饮项目创业计划书
2014/02/02 职场文书
西双版纳导游词
2015/02/03 职场文书
检讨书怎么写
2015/05/07 职场文书
中秋节晚会开场白
2015/05/29 职场文书
老乡会致辞
2015/07/28 职场文书
2016年教师学习廉政准则心得体会
2016/01/20 职场文书
Java框架入门之简单介绍SpringBoot框架
2021/06/18 Java/Android