当前位置: 首页 > news >正文

在网站做登记表备案 如果修改优化大师破解版app

在网站做登记表备案 如果修改,优化大师破解版app,哪个网站可以免费做H5,微信超市小程序函数防抖和节流在前端开发的过程中,我们经常会需要绑定一些持续触发的事件,如 resize、scroll、mousemove 等等,但有些时候我们并不希望在事件持续触发的过程中那么频繁地去执行函数。通常这种情况下我们怎么去解决的呢?一般来讲&…

函数防抖和节流

在前端开发的过程中,我们经常会需要绑定一些持续触发的事件,如 resize、scroll、mousemove 等等,但有些时候我们并不希望在事件持续触发的过程中那么频繁地去执行函数。

通常这种情况下我们怎么去解决的呢?一般来讲,防抖和节流是比较好的解决方案。

让我们先来看看在事件持续触发的过程中频繁执行函数是怎样的一种情况。

html 文件中代码如下

<div id="content" style="height:150px;line-height:150px;text-align:center; color: #fff;background-color:#ccc;font-size:80px;"></div>
var num = 1;
var content = document.getElementById('content');
function count() {
content.innerHTML = num++;
};
content.onmousemove = count;
复制代码

在上述代码中,div 元素绑定了 mousemove 事件,当鼠标在 div(灰色)区域中移动的时候会持续地去触发该事件导致频繁执行函数。效果如下

可以看到,在没有通过其它操作的情况下,函数被频繁地执行导致页面上数据变化特别快。所以,接下来让我们来看看防抖和节流是如何去解决这个问题的。

防抖(debounce)

所谓防抖,就是指触发事件后在 n 秒内函数只能执行一次,如果在 n 秒内又触发了事件,则会重新计算函数执行时间。

防抖函数分为非立即执行版和立即执行版。

非立即执行版:

function debounce(func, wait) {
var timeout;
return function () {
var context = this;
var args = arguments;
if (timeout) clearTimeout(timeout);
timeout = setTimeout(function () {
func.apply(context, args)
},
wait);
}
}
复制代码

非立即执行版的意思是触发事件后函数不会立即执行,而是在 n 秒后执行,如果在 n 秒内又触发了事件,则会重新计算函数执行时间。

我们依旧使用上述绑定 mousemove 事件的例子,通过上面的防抖函数,我们可以这么使用

content.onmousemove = debounce(count,1000); 复制代码

效果如下

可以看到,在触发事件后函数 1 秒后才执行,而如果我在触发事件后的 1 秒内又触发了事件,则会重新计算函数执行时间。

上述防抖函数的代码还需要注意的是 this 和 参数的传递

var context = this; var args = arguments; 复制代码

防抖函数的代码使用这两行代码来获取 this 和 参数,是为了让 debounce 函数最终返回的函数 this 指向不变以及依旧能接受到 e 参数。

立即执行版:

function debounce(func,wait) {     var timeout;      return function () {         var context = this;         var args = arguments;          if (timeout) clearTimeout(timeout);          var callNow = !timeout;         timeout = setTimeout(function(){             timeout = null;         }, wait)          if (callNow) func.apply(context, args)     } } 复制代码

立即执行版的意思是触发事件后函数会立即执行,然后 n 秒内不触发事件才能继续执行函数的效果。

使用方法同上,效果如下

在开发过程中,我们需要根据不同的场景来决定我们需要使用哪一个版本的防抖函数,一般来讲上述的防抖函数都能满足大部分的场景需求。但我们也可以将非立即执行版和立即执行版的防抖函数结合起来,实现最终的双剑合璧版的防抖函数。

双剑合璧版:

/**  * @desc 函数防抖  * @param func 函数  * @param wait 延迟执行毫秒数  * @param immediate true 表立即执行,false 表非立即执行  */ function debounce(func,wait,immediate) {     var timeout;      return function () {         var context = this;         var args = arguments;          if (timeout) clearTimeout(timeout);         if (immediate) {             var callNow = !timeout;             timeout = setTimeout(function(){                 timeout = null;             }, wait)             if (callNow) func.apply(context, args)         }         else {             timeout = setTimeout(function(){                 func.apply(context, args)             }, wait);         }     } } 复制代码

节流(throttle)

**所谓节流,就是指连续触发事件但是在 n 秒中只执行一次函数。**节流会稀释函数的执行频率。

对于节流,一般有两种方式可以实现,分别是时间戳版和定时器版。

时间戳版:

function throttle(func, wait) {     var previous = 0;      return function() {         var now = Date.now();         var context = this;         var args = arguments;         if (now - previous > wait) {             func.apply(context, args);             previous = now;         }     } } 复制代码

使用方式如下

content.onmousemove = throttle(count,1000); 复制代码

效果如下

可以看到,在持续触发事件的过程中,函数会立即执行,并且每 1s 执行一次。

定时器版:

function throttle(func, wait) {     var timeout;      return function() {         var context = this;         var args = arguments;         if (!timeout) {             timeout = setTimeout(function(){                 timeout = null;                 func.apply(context, args)             }, wait)         }      } } 复制代码

使用方式同上,效果如下

可以看到,在持续触发事件的过程中,函数不会立即执行,并且每 1s 执行一次,在停止触发事件后,函数还会再执行一次。

我们应该可以很容易的发现,其实时间戳版和定时器版的节流函数的区别就是,时间戳版的函数触发是在时间段内开始的时候,而定时器版的函数触发是在时间段内结束的时候。

同样地,我们也可以将时间戳版和定时器版的节流函数结合起来,实现双剑合璧版的节流函数。

双剑合璧版:

/**  * @desc 函数节流  * @param func 函数  * @param wait 延迟执行毫秒数  * @param type 1 表时间戳版,2 表定时器版  */ function throttle(func, wait ,type) {     if(type===1){         var previous = 0;     }else if(type===2){         var timeout;     }      return function() {         var context = this;         var args = arguments;         if(type===1){             var now = Date.now();              if (now - previous > wait) {                 func.apply(context, args);                 previous = now;             }         }else if(type===2){             if (!timeout) {                 timeout = setTimeout(function(){                     timeout = null;                     func.apply(context, args)                 }, wait)             }         }      } } 

转载于:https://www.cnblogs.com/yayaxuping/p/9728387.html

http://www.lbrq.cn/news/2496313.html

相关文章:

  • wdcp拒绝访问网站十大免费无代码开发软件
  • wordpress次级目录ftp廊坊seo关键词优化
  • 好看的学校网站模板免费下载关键词歌词含义
  • 徐州建站软件现在有什么推广平台
  • 网站服务器试用百度的总部在哪里
  • 怎么仿别人的网站近几天发生的新闻大事
  • 网站建设教程答允苏州久远网络产品推广宣传方案
  • 广州企业网站建设推荐网店营销策略有哪些
  • 网站建设咨询公国内新闻最新消息今天
  • 珠海市网站建设公司网站建设与优化
  • html模板网站想做电商应该怎么入门
  • 网站建设推广报价单2023年国际新闻大事件10条
  • 品牌建设网站唐山seo
  • 深圳网站设计公司软文推广多少钱
  • 网站建设 精品课程友情链接交换形式有哪些
  • 网站开发课程设计培训网上广告怎么推广
  • 制作一个简单网站seo群发软件
  • 重庆红旗河沟网站建设seo搜索优化专员招聘
  • 广州网站制作公司神马seo服务
  • wordpress 好用的插件推荐优化设计三年级上册语文答案
  • 网站页面优化简单吗长沙seo全网营销
  • 织梦做的网站图片路径在哪万网阿里云域名查询
  • 软装设计公司网站网络推广员怎么做
  • 用dw做音乐网站系统的代码推广普通话内容50字
  • 普陀网页设计优化手机流畅度的软件
  • 网站开发人才哪些平台可以发广告
  • 乌克兰集团网站建设佛山市人民政府门户网站
  • 织梦做的网站网速打开慢是怎么回事seo咨询常德
  • 唐山建设局网站建网站费用
  • 私人网站如何建学生个人网页制作成品代码
  • 嵌入式基础知识复习(7.28)
  • 数据库原理
  • vue 脚手架配置代理
  • RCE真实漏洞初体验
  • 力扣面试150题--寻找旋转排序数组中的最小值
  • Axios基本使用