>>分享Web前端开发技术,并对孙卫琴的《精通Vue.js:Web前端开发技术详解》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 25017 个阅读者 刷新本主题
 * 贴子主题:  vue 项目中使用loadsh 的 防抖(debounce)和节流(throttle) 回复文章 点赞(0)  收藏  
作者:flybird    发表时间:2025-10-16 10:16:53     消息  查看  搜索  好友  邮件  复制  引用

使用场景: 首次调用执行一次,一定时间内再次调用,不再执行。

实现方式:

   1. debounce (函数去抖) 多次触发,只在最后一次触发时,执行目标函数。

_.debounce(func, [wait=0], [options={}])
    2. throttle (函数节流)限制目标函数调用的频率,比如:1s内不能调用2次。

_.throttle(func, [wait=0], [options={}])
lodash在opitons参数中定义了一些选项,具体用法去看下lodash;

案例场景: 一个控制摄像头的方向的控制盘,因为数据返回的速度真的有点感人,点击后大概十秒摄像头才会返回操作后的画面。

容易让人重复点击,所以用节流去实现比较合适,使用写法如下:
<div class='controller'>
        <ul class='pie'>
            <li class='slice-one slice' @click="onClick(1)"><a><img src="../img/icon2.png" alt=""></a></li>
            <li class='slice-two slice' @click="onClick(6)"><a><img src="../img/icon2.png" alt=""></a></li>
            <li class='slice-three slice' @click="onClick(4)"><a><img src="../img/icon2.png" alt=""></a></li>
            <li class='slice-four slice' @click="onClick(8)"><a><img src="../img/icon2.png" alt=""></a></li>
            <li class='slice-five slice' @click="onClick(2)"><a><img src="../img/icon2.png" alt=""></a></li>
            <li class='slice-six slice' @click="onClick(7)"><a><img src="../img/icon2.png" alt=""></a></li>
            <li class='slice-seven slice' @click="onClick(3)"><a><img src="../img/icon2.png" alt=""></a></li>
            <li class='slice-eight slice' @click="onClick(5)"><a><img src="../img/icon2.png" alt=""></a></li>
            <div class="center"></div>
        </ul>
    </div>

export default {
    name: '',
    data() {
      return {
        controlTime: globalConstant.controlTime, // 控制时长
        throttle: null
      };
    },
    props: {
      videoPlatformCofig: {
        type: Object,
        default: function() {
          return {

          }
        }
      }
    },
    components: {},
    computed: {},
    created() {
    },
    methods: {
      // 点击
      onClick(index) {
        this.throttle(index)
      }
    },
    mounted() {
      this.throttle = _.throttle(function(direction) {
        const vo = {
          direction: direction,
          controlTime: this.controlTime,
          code: this.videoPlatformCofig.code,
          channelNo: this.videoPlatformCofig.channelNo
        }
        videoControl.direction(vo).then(response => {
          this.$Message.success('操作成功,请耐心等待')
        })
      }, 10000)
    }
  }

程序猿的技术大观园:www.javathinker.net
  Java面向对象编程-->面向对象开发方法概述之UML语言(下)
  JavaWeb开发-->在Web应用中访问Web服务
  JSP与Hibernate开发-->Spring、JPA与Hibernate的整合
  Java网络编程-->用Spring整合CXF发布Web服务
  精通Spring-->
  Vue3开发-->通过Vuex进行状态管理
  键盘按键与 键码对照表
  不可错过的几种JS优化技巧
  Vue选项的用法
  Vue用法详解
  css 实现不定数量的tab切换和页面切换
  JS对树形数据的遍历和过滤,
  理解前后端分离的概念
  js导出json文件
  JavaScript中的HTML DOM Button 对象
  HTML DOM Script 对象
  JavaScript的HTML DOM Column 对象
  CSS 听觉参考手册
  HTML5 播放Audio(音频)
  JavaScript 测试 jQuery
  JavaScript 函数 的定义和使用
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。