web项目开发之JS函数防抖与节流示例代码

 更新时间:2021年09月24日 14:32:10   作者:SpringSir  
这篇文章主要介绍了web项目开发之JS函数防抖与节流实现的示例代码及原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助

防抖

经典应用常见: 手风琴效果

引入

没有做防抖的网站:

在这里插入图片描述

做了防抖的网站:

请添加图片描述 

防抖场景1(鼠标移入)

抖动 : 用户本来不想触发这个交互,但是由于鼠标不小心抖动误触发交互事件。
例子: 想看第五张图片,。不想看2 3 4张。 但是鼠标从第1张滑到第五张时候,不小心放在了2 3 4上面。误触发。

函数防抖 : 用户连续多次触发某个事件,则只执行最后一次。

解决原理: 开启定时器,间隔时间内如果多次触发事件,则每一次都清除上一次定时器。

实例及解决代码:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>动画-案例《手风琴》</title>
    <style>
      * {
        margin: 0;
        padding: 0;
      }
      ul {
        list-style: none;
        width: 2400px;
      }
      #box {
        width: 1200px;
        height: 400px;
        border: 1px solid red;
        margin: 100px auto;
        overflow: hidden;
      }
      #box li {
        width: 100px;
        height: 400px;
        float: left;
        transition: all 0.5s ease-out;
      }
      #box li.over {
        width: 800px;
      }
    </style>
  </head>

  <body>
    <div id="box">
      <ul>
        <li v-for="(item,index) in list" :class="{over:overIndex == index}" @mouseenter="doEnter(index)">
            <img :src="item" alt="">
        </li>
      </ul>
    </div>
    <script src="./vue.js"></script>
    <script>
      let app = new Vue({
          el:'#box',
          data:{
              overIndex:0,
              list:[
                  './images/collapse/1.jpg',
                  './images/collapse/2.jpg',
                  './images/collapse/3.jpg',
                  './images/collapse/4.jpg',
                  './images/collapse/5.jpg',
              ],
              timeID:null
          },
          methods: {
              doEnter(index){
                  /* 开启防抖 */
                  //1.1 先清除上一次定时器,以本次为准
                  clearTimeout(this.timeID)
                  //1.2 开启定时器(防抖间隔)
                  this.timeID = setTimeout(()=>{
                    this.overIndex = index;
                  },500)
              }
          },
      })
    </script>
  </body>
</html>

防抖场景2(键盘按键)

经典应用场景: 搜索联想词
-开发中, 该功能后端会使用中间件"OpenSearch"或者"Elasticsearch", 后端的逻辑处理会十分高效、快捷.
-此处只是基于前端的角度, 从减少http请求这个方面出发来进行优化

<!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>
</head>
<body>
    <input type="text" placeholder="请输入搜索内容">
    <script>
        let timeID = null;
        document.querySelector('input').oninput = function(){
            /* 函数防抖 */
            //(1)先清除以前的定时器
            clearTimeout(timeID)
            //(2)开启防抖定时器
            timeID = setTimeout(() => {
                console.log( this.value );
            }, 500);
        }
    </script>
</body>
</html>

函数节流

概念: 解决高频事件带来的性能问题;高频事件: 在页面中,有些事件触发频率非常的高。
例如: 鼠标移动,滚轮事件。

解决原理: 用户连续多次触发事件,指定时间内只会触发一次

实例及解决代码:

<!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>
        body{
            height: 3000px;
        }
    </style>
</head>
<body>
    <script>
        let lastTime = null;
        
        let i = 1;
        window.onmousemove = function(){
            /* 函数节流 */
            //(1)判断两次触发事件的时间间隔
            let time = Date.now()
            if( time - lastTime >= 500 ){
                console.log('鼠标移动次数:' + i++);
                //(2)本次触发时间作为下一次参考间隔
                lastTime = time
            }
        }
        // let j = 1;
        // window.onscroll = function(){
        //     //(1)判断两次触发事件的时间间隔
        //     let time = Date.now()
        //     if( time - lastTime >= 500 ){
        //         console.log('鼠标滚动次数:' + j++);
        //         //(2)本次触发时间作为下一次参考间隔
        //         lastTime = time
        //     }   
        // }
    </script>
</body>
</html>

以上就是web项目开发之JS函数防抖与节流示例代码的详细内容,更多关于web项目JS函数防抖与节流的资料请关注脚本之家其它相关文章!

相关文章

  • JS重载实现方法分析

    JS重载实现方法分析

    这篇文章主要介绍了JS重载实现方法,结合实例形式分析了javascript重载的实现与使用方法,需要的朋友可以参考下
    2016-12-12
  • Javascript类型系统之String字符串类型详解

    Javascript类型系统之String字符串类型详解

    这篇文章主要介绍了Javascript类型系统之String字符串类型详解的相关资料,需要的朋友可以参考下
    2016-06-06
  • 前端技巧之js-md5的简单使用方法

    前端技巧之js-md5的简单使用方法

    这篇文章主要给大家介绍了关于前端技巧之js-md5的简单使用,js-md5是一种前端加密算法,用于在前端对密码等敏感信息进行加密,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • momentjs获取上周、上月、前三个月的起始和结束时间(附完整代码)

    momentjs获取上周、上月、前三个月的起始和结束时间(附完整代码)

    这篇文章主要给大家介绍了关于momentjs获取上周、上月、前三个月的起始和结束时间的相关资料,在需要你进行日期处理的地方,必然少不了moment.js的使用,需要的朋友可以参考下
    2023-07-07
  • JS中JSON对象和String之间的互转及处理技巧

    JS中JSON对象和String之间的互转及处理技巧

    JSON:JavaScript 对象表示法(JavaScript Object Notation),其实JSON就是一个JavaScript的对象(Object)而已。接下来通过本文给大家介绍JS中JSON对象和String之间的互转及处理技巧,需要的朋友一起学习吧
    2016-04-04
  • js获取标签元素data-*属性值的4种方法

    js获取标签元素data-*属性值的4种方法

    这篇文章主要分享了js获取标签元素data-*属性值的4种方法,标签上有两个属性​​data-id​​​ 和 ​​data-user-name​​, 需要通过js去获取,下面文章具体介绍需要的小伙伴可以参考一下
    2022-06-06
  • JS显示表格内指定行html代码的方法

    JS显示表格内指定行html代码的方法

    这篇文章主要介绍了JS显示表格内指定行html代码的方法,涉及javascript获取行及innerHTML属性的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • 实现抖音两个旋转小球的loading技巧实例

    实现抖音两个旋转小球的loading技巧实例

    这篇文章主要为大家介绍了实现抖音两个旋转小球的loading技巧实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • 原生JS实现N级菜单的代码

    原生JS实现N级菜单的代码

    最近有项目要实现N级菜单,首先从布局入手,即判断是否有下级菜单,具体实现代码,大家可以参考下本文
    2017-05-05
  • js 单引号替换成双引号,双引号替换成单引号的实现方法

    js 单引号替换成双引号,双引号替换成单引号的实现方法

    下面小编就为大家带来一篇js 单引号替换成双引号,双引号替换成单引号的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02

最新评论