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

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

实现方式:

   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开发-->JSP技术详解(Ⅰ)
  JSP与Hibernate开发-->立即检索和延迟检索策略
  Java网络编程-->安全网络通信
  精通Spring-->Vue Router路由管理器
  Vue3开发-->Vue组件开发基础
  10个开发者经常问的JavaScript面试题(附答案解析)
  常用CSS样式属性大全
  qs.parse()、qs.stringify()、JSON.stringify() 用法及区别
  Promise对象的then()和catch()方法
  前端面试官指导前端面试攻略
  JavaScript输出格式化日期和时间
  js导出json文件
  响应式 Web 设计:显示图片
  JavaScript 代码规范
  JavaScript prototype(原型对象)
  JavaScript 严格模式(use strict)
  JavaScript 调试
  JavaScript 正则表达式
  JavaScript中的for 循环
  一文读懂前端技术演进:盘点Web前端20年的技术变迁史
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


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