广告
返回顶部
首页 > 资讯 > 精选 >JavaScript中节流的示例分析
  • 131
分享到

JavaScript中节流的示例分析

2023-06-06 19:06:29 131人浏览 薄情痞子
摘要

小编给大家分享一下javascript中节流的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言我们来聊一聊节流——另一个优化函数的思想。我们还是以移动事

小编给大家分享一下javascript中节流的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

前言

我们来聊一聊节流——另一个优化函数的思想。

我们还是以移动事件举例

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <meta Http-equiv="X-UA-Compatible" content="ie=edge">    <title>Document</title>    <style>        #wrapper {            width: 100%;            height: 140px;            background: rgba(0, 0, 0, 0.8);            color: #fff;            font-size: 30px;            font-weight: bold;            line-height: 140px;            text-align: center;        }    </style></head><body>    <p id="wrapper"></p>    <script>        var count = 1;        function moveAction () {            oWrapper.innerHTML = count++;        }        var oWrapper = document.querySelector('#wrapper');oWrapper.onmousemove = moveAction;    </script></body></html>

它的效果是这样:

JavaScript中节流的示例分析

一、核心和基本实现

节流的原理很简单:如果你持续触发某个事件,特定的时间间隔内,只执行一次。

关于节流的实现,有两种主流的实现方式:

  1. 时间戳思路

  2. 定时器思路

1.1 时间戳思路

顾名思义,通过两个时间戳来控制时间间隔,当触发事件的时候:

  1. 我们取出当前的时间戳 now

  2. 然后减去之前执行时的时间戳(首次值为 0 ) prev

  3. 如果大now - prev > wait,证明时间区间维护结束,执行指定事件,更新prev

根据这一思路,我们就可以实现第一版代码了:

oWrapper.onmousemove = throttle(moveAction, 1000);function throttle(func, wait) {    var _this, arg;    var prev = 0; // 上一次触发的时间,第一次默认为0    return function () {        var now = Date.now(); // 触发时的时间        _this = this;        if (now - prev > wait) {            func.apply(_this, arg); // 允许传入参数,并修正this            prev = now; // 更新上一次触发的时间        }    }}

来看看借助它,效果是什么样的:

JavaScript中节流的示例分析

我们可以看到:

  1. 当鼠标移入的时候,事件立刻执行

  2. 每过 1s 会执行一次,且移动2.5s会执行2次,意味着动作停止后不会再执行

1.2 定时器思路

利用定时器来保证间隔时间内事件的触发次数

  1. 创建定时器timer,记录当前是否在周期内;

  2. 判断定时器是否存在,若存在则直接结束,否则执行事件;

  3. wait时间之后再次执行,并清掉定时器;

当触发事件的时候,我们设置一个定时器,再触发事件的时候,如果定时器存在,就不执行,直到定时器执行,然后执行函数,清空定时器,这样就可以设置下个定时器。

function throttle(func, wait) {    var _this, arg;    var timer; // 初始化    return function () {        _this = this; // 记录this        arg = arguments; // 记录参数数组        if (timer) return; // 时候未到        timer = setTimeout(() => {            func.apply(_this, arg); // 允许传入参数,并修正this            timer = null;        }, wait);    }}

来看看借助它,效果是什么样的:

JavaScript中节流的示例分析

但是,我们可以看到:

  1. 当鼠标移入的时候,事件不会立刻执行;

  2. 鼠标定制后wait间隔后会执行一次

1.3 两种思路的区别

时间戳定时器
“起点”立即执行n 秒后执行
“终点”停止后不会执行停止会再执行一次

二、节流进阶

结合两种思想完成一个可以立即执行,且停止触发后再执行一次的节流方法:

// 第三版function throttle(func, wait) {    var timeout, context, args, result;    var previous = 0;    var later = function() {        previous = +new Date();        timeout = null;        func.apply(context, args)    };    var throttled = function() {        var now = +new Date();        //下次触发 func 剩余的时间        var remaining = wait - (now - previous);        context = this;        args = arguments;         // 如果没有剩余的时间了或者你改了系统时间        if (remaining <= 0 || remaining > wait) {            if (timeout) {                clearTimeout(timeout);                timeout = null;            }            previous = now;            func.apply(context, args);        } else if (!timeout) {            timeout = setTimeout(later, remaining);        }    };    return throttled;}

效果演示如下:

JavaScript中节流的示例分析

我在看代码的时候,我是反复打印数据才理解为什么会这样做,一起加油~

以上是“JavaScript中节流的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: JavaScript中节流的示例分析

本文链接: https://www.lsjlt.com/news/248316.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中节流的示例分析
    小编给大家分享一下JavaScript中节流的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言我们来聊一聊节流——另一个优化函数的思想。我们还是以移动事...
    99+
    2023-06-06
  • JavaScript中函数节流的示例分析
    这篇文章给大家分享的是有关JavaScript中函数节流的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。JavaScript 函数节流详解浏览器一个网页的UI线程只有一个...
    99+
    2022-10-19
  • JavaScript节流与防抖实例分析
    本篇内容主要讲解“JavaScript节流与防抖实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript节流与防抖实例分析”吧!一、js防抖和节流在进行窗口的resize、sc...
    99+
    2023-06-29
  • JavaScript事件流的示例分析
    这篇文章主要介绍JavaScript事件流的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.什么是事件流 ?在学习事件流之前我们先看看什么是事件 ?事件代表文档或浏览器窗口中某个有意义的时刻即用户与页面的交...
    99+
    2023-06-29
  • js中函数节流与防抖的示例分析
    小编给大家分享一下js中函数节流与防抖的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!js 的节流与防抖函数防抖&nbs...
    99+
    2022-10-19
  • Java中IO操作字节流与字符流的示例分析
    这篇文章主要为大家展示了“Java中IO操作字节流与字符流的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Java中IO操作字节流与字符流的示例分析”这篇文章吧。IO操作字节流java....
    99+
    2023-06-29
  • Java IO中字节输入输出流的示例分析
    这篇文章主要介绍Java IO中字节输入输出流的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!讲的是字节输入输出流:InputStream、OutputSteam(下图红色长方形框内),红色椭圆框内...
    99+
    2023-06-26
  • Javascript柯里化流程的示例分析
    这篇文章将为大家详细讲解有关Javascript柯里化流程的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。函数式编程是一种如今比较流行的编程范式,它主张将函数作为...
    99+
    2022-10-19
  • HTML中DOM节点的示例分析
    小编给大家分享一下HTML中DOM节点的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!  在HTML DOM中,所有事物...
    99+
    2022-10-19
  • JQuery中DOM节点的示例分析
    小编给大家分享一下JQuery中DOM节点的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体如下:Jquery中DOM...
    99+
    2022-10-19
  • Javascript中DOM、节点和获取元素的示例分析
    这篇文章给大家分享的是有关Javascript中DOM、节点和获取元素的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。DOM文档:DOM中的“D”,当创建一个网页并把它加载到Web浏览器中时,它把编写的网...
    99+
    2023-06-25
  • JS函数防抖和函数节流的示例分析
    这篇文章主要介绍JS函数防抖和函数节流的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!概述函数防抖和函数节流都是定义一个函数,该函数接收一个函数作为参数,并返回一个添加了防抖或节流功能后的函数。因此可以将函数...
    99+
    2023-06-15
  • Vue中click事件防抖和节流处理的示例分析
    小编给大家分享一下Vue中click事件防抖和节流处理的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!函数防抖定义:多次...
    99+
    2022-10-19
  • Java中IO流的示例分析
    这篇文章主要为大家展示了“Java中IO流的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Java中IO流的示例分析”这篇文章吧。I/O简介I/O是Input/output的缩写,在ja...
    99+
    2023-06-20
  • JavaScript中Cookie的示例分析
    小编给大家分享一下JavaScript中Cookie的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Cookie1.js...
    99+
    2022-10-19
  • JavaScript中Ajax的示例分析
    这篇文章给大家分享的是有关JavaScript中Ajax的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Ajax1.创建步骤:1.创建一个XMLHttpRequest异步...
    99+
    2022-10-19
  • javascript中 “this”的示例分析
    小编给大家分享一下javascript中 “this”的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、前言:我们知道...
    99+
    2022-10-19
  • JavaScript中EventEmitter的示例分析
    这篇文章将为大家详细讲解有关JavaScript中EventEmitter的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。什么是 Event EmitterEve...
    99+
    2022-10-19
  • javascript中Hoisting的示例分析
    这篇文章给大家分享的是有关javascript中Hoisting的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。简介“变量提升”意味着变量和函数的声明会在物理层面移动到代...
    99+
    2022-10-19
  • JavaScript中Date的示例分析
    这篇文章主要介绍了JavaScript中Date的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Date函数new Date() D...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作