JavaScript函数节流的两种写法


Posted in Javascript onApril 07, 2017

最近看了函数节流的相关内容,具体什么是节流我不讨论了,网上很多,这里总结下两个方法,我只认可其中一个。另一个貌似也能达到节流的效果但是感觉不是很正规。

方法一:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>函数节流</title>
 <style>
 div{
  font-size:40px;
  color:red;
  text-align: center;
 }
 </style>
</head>
<body>
<div>0</div>
 <script>
var a=0;
 var oDiv=document.getElementsByTagName('div')[0];
 var throttle=function(fn,wait){
 var startTime=new Date();
 return function(){
  var arg=arguments;
  var context=this;
  var curTime=new Date();
  // 如果达到了规定的触发时间间隔,触发 handler
  var remaing=wait-(curTime-startTime)
  if(remaing<=0||remaing>wait){//按理说remaing足够证明已经到了时间间隔,但是为了防止客户端修改了时间所以加个条件(为什么这么加我也不懂)
  fn.apply(context,arg);
  startTime=curTime;
  }
 };
 };
 window.onmousemove=throttle(function(){
  a++;
  oDiv.innerText=a+"";
 },2000);
 </script>
</body>
</html>

我比较认可这个方法,另外这是简洁版,还有一种可以是这样子的

function throttle(fun, delay, time) {
  var timeout,
    startTime = new Date();
  return function() {
    var context = this,
      args = arguments,
      curTime = new Date();
    clearTimeout(timeout);
    // 如果达到了规定的触发时间间隔,触发 handler
    if (curTime - startTime >= time) {
      fun.apply(context, args);
      startTime = curTime;
      // 没达到触发间隔,重新设定定时器
    } else {
      timeout = setTimeout(function(){
       fun.apply(context, args);
      }, delay);
    }
  };
};

就是在判断完时间间隔后再加个计时器来延迟,这个我觉得加不加都行,加了也没错跟时间判断互补,不加也能实现节流的效果。

第二类写法:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>函数节流</title>
 <style>
 div{
  font-size:40px;
  color:red;
  text-align: center;
 }
 </style>
</head>
<body>
<div>0</div>
 <script>
 var a=0;
 var oDiv=document.getElementsByTagName('div')[0];
 var throttle=function(fn,time){
  var timer=null;
  return function(){
  var arg=arguments;
  var context=this;
  if(timer){
   return false;
  }
  else{
  timer=setTimeout(function(){
   clearTimeout(timer);
   timer=null;
   fn.apply(context,arg);
  },time);
  }
 };
 };
 window.onmousemove=throttle(function(){
   a++;
 oDiv.innerText=a+"";
  },2000);
 </script>
</body>
</html>

这种写法通过判断是否存在正在进行的计时器来决定是否执行函数,存在就结束运行函数,但是那个计时器仍在队列里进行实践一到还会执行,通过运行也能达到节流,也就是间隔固定的时间触发函数,但是我就是不太喜欢这种写法。可能是这种方法没第一种直接吧。 

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
document.onreadystatechange事件的用法分析
Oct 17 Javascript
在Iframe中获取父窗口中表单的值(示例代码)
Nov 22 Javascript
js格式化时间和js格式化时间戳示例
Feb 10 Javascript
js实现简单锁屏功能实例
May 27 Javascript
拥Bootstrap入怀——导航栏篇
May 30 Javascript
JS实用的带停顿的逐行文本循环滚动效果实例
Nov 23 Javascript
Javascript实现从小到大的数组转换成二叉搜索树
Jun 13 Javascript
vue实现组件之间传值功能示例
Jul 13 Javascript
JavaScript常见JSON操作实例分析
Aug 08 Javascript
JQuery通过后台获取数据遍历到前台的方法
Aug 13 jQuery
js与jquery获取input输入框中的值实例讲解
Feb 27 jQuery
vue 弹出遮罩层样式实例
Jul 22 Javascript
原生JS实现圆环拖拽效果
Apr 07 #Javascript
Zepto实现密码的隐藏/显示
Apr 07 #Javascript
js按条件生成随机json:randomjson实现方法
Apr 07 #Javascript
详解JS中遍历语法的比较
Apr 07 #Javascript
JavaScript原生数组Array常用方法
Apr 06 #Javascript
微信小程序 图片宽度自适应的实现
Apr 06 #Javascript
微信小程序 下拉菜单的实现
Apr 06 #Javascript
You might like
四月新番又没了,《Re:从零开始的异世界生活》第二季延期至7月播出
2020/05/06 日漫
php 清除网页病毒的方法
2008/12/05 PHP
PHP获取文件绝对路径的代码(上一级目录)
2011/05/29 PHP
深入PHP curl参数的详解
2013/06/17 PHP
摘自百度的图片轮换效果代码
2007/11/19 Javascript
读jQuery之十一 添加事件核心方法
2011/07/31 Javascript
限制textbox或textarea输入字符长度的JS代码
2013/10/16 Javascript
JS实现的3D拖拽翻页效果代码
2015/10/31 Javascript
JS与jQuery遍历Table所有单元格内容的方法
2015/12/07 Javascript
angular中实现控制器之间传递参数的方式
2017/04/24 Javascript
微信小程序网络请求wx.request详解及实例
2017/05/18 Javascript
详解AngularJS脏检查机制及$timeout的妙用
2017/06/19 Javascript
vue上传图片组件编写代码
2017/07/26 Javascript
谈谈JS中的!!
2017/12/07 Javascript
babel之配置文件.babelrc入门详解
2018/02/22 Javascript
JS加密插件CryptoJS实现的Base64加密示例
2020/08/16 Javascript
Vuex 在Vue 组件中获得Vuex 状态state的方法
2018/08/27 Javascript
详解JQuery基础动画操作
2019/04/12 jQuery
浅谈layui分页控件field参数接收对象的问题
2019/09/20 Javascript
使用Vue+Django+Ant Design做一个留言评论模块的示例代码
2020/06/01 Javascript
[40:55]DOTA2上海特级锦标赛主赛事日 - 2 败者组第二轮#4Newbee VS Fnatic
2016/03/03 DOTA
[01:32:50]DOTA2-DPC中国联赛 正赛 DLG vs XG BO3 第一场 1月25日
2021/03/11 DOTA
Python字典操作简明总结
2015/04/13 Python
python通过ssh-powershell监控windows的方法
2015/06/02 Python
Tensorflow中使用tfrecord方式读取数据的方法
2018/06/19 Python
Django上使用数据可视化利器Bokeh解析
2019/07/31 Python
在Matplotlib图中插入LaTex公式实例
2020/04/17 Python
基于Python实现简单学生管理系统
2020/07/24 Python
CSS3中Animation属性的使用详解
2015/08/06 HTML / CSS
5个你不知道的HTML5的接口介绍
2013/08/07 HTML / CSS
华润集团网上药店:健一网
2016/09/19 全球购物
法律专业个人实习自我鉴定
2013/09/23 职场文书
移动通信专业自荐信范文
2013/11/12 职场文书
采购部长岗位职责
2014/06/13 职场文书
瘦西湖导游词
2015/02/03 职场文书
Java数组与堆栈相关知识总结
2021/06/29 Java/Android