通过实例讲解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 相关文章推荐
javascript parseInt 函数分析(转)
Mar 21 Javascript
解析javascript 浏览器关闭事件
Jul 08 Javascript
jquery+php实现搜索框自动提示
Nov 28 Javascript
原生javaScript实现图片延时加载的方法
Dec 22 Javascript
js显示动态时间的方法详解
Aug 20 Javascript
第一次接触神奇的Bootstrap
Oct 14 Javascript
js基于myFocus实现轮播图效果
Feb 14 Javascript
解决给dom元素绑定click等事件无效问题的方法
Feb 17 Javascript
单行 JS 实现移动端金钱格式的输入规则
May 22 Javascript
js实现上传并压缩图片效果
Jan 10 Javascript
javascript显示动态时间的方法汇总
Jul 06 Javascript
小程序自定义轮播图圆点组件
Jun 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
在线增减.htpasswd内的用户
2006/10/09 PHP
PHP中实现中文字符进制转换原理分析
2011/12/06 PHP
php上传图片获取路径及给表单字段赋值的方法
2016/01/23 PHP
PHP文件上传处理案例分析
2016/10/15 PHP
Yii2框架自定义类统一处理url操作示例
2019/05/25 PHP
php文件上传原理与实现方法详解
2019/12/20 PHP
Nigma vs Alliance BO5 第一场2.14
2021/03/10 DOTA
Prototype Function对象 学习
2009/07/12 Javascript
Javascript在IE或Firefox下获取鼠标位置的代码
2009/12/18 Javascript
关于UTF-8的客户端用AJAX方式获取GB2312的服务器端乱码问题的解决办法
2010/11/30 Javascript
Jquery动态更改一张位图的src与Attr的使用
2013/07/31 Javascript
JS实现匀速运动的代码实例
2013/11/29 Javascript
js之ActiveX控件使用说明 new ActiveXObject()
2014/03/03 Javascript
深入分析escape()、encodeURI()、encodeURIComponent()的区别及示例
2014/08/04 Javascript
JavaScript模拟实现继承的方法
2015/03/30 Javascript
基于Jquery和html5的7款个性化地图插件
2015/11/17 Javascript
jQuery实现点击水纹波动动画
2016/04/10 Javascript
移动端js触摸事件详解
2016/09/18 Javascript
js通过keyCode值判断单击键盘上某个键,然后触发指定的事件方法
2017/02/19 Javascript
JavaScript实现动态增删表格的方法
2017/03/09 Javascript
ES6新特性三: Generator(生成器)函数详解
2017/04/21 Javascript
JS使用队列对数组排列,基数排序算法示例
2019/03/02 Javascript
vue.js实现照片放大功能
2020/06/23 Javascript
Python中几个比较常见的名词解释
2015/07/04 Python
python 中的divmod数字处理函数浅析
2017/10/17 Python
简单谈谈python中的lambda表达式
2018/01/19 Python
python 不以科学计数法输出的方法
2018/07/16 Python
win10下tensorflow和matplotlib安装教程
2018/09/19 Python
css3中单位px,em,rem,vh,vw,vmin,vmax的区别及浏览器支持情况
2016/12/06 HTML / CSS
学习十八大报告感言
2014/02/04 职场文书
邮政竞聘演讲稿
2014/09/03 职场文书
2014离婚协议书范文
2014/09/10 职场文书
领导干部个人对照检查材料(群众路线)
2014/09/26 职场文书
2016年春季运动会加油稿
2015/07/22 职场文书
2019毕业典礼主持词!
2019/07/05 职场文书
2019通用版劳动合同范本!
2019/07/11 职场文书