当前位置: 首页 > 编程笔记 >

angular.js和vue.js中实现函数去抖示例(debounce)

严欣怡
2023-03-14
本文向大家介绍angular.js和vue.js中实现函数去抖示例(debounce),包括了angular.js和vue.js中实现函数去抖示例(debounce)的使用技巧和注意事项,需要的朋友参考一下

问题描述

搜索输入框中,只当用户停止输入后,才进行后续的操作,比如发起Http请求等。

学过电子电路的同学应该知道按键防抖。原理是一样的:就是说当调用动作n毫秒后,才会执行该动作,若在这n毫秒内又调用此动作则将重新计算执行时间。本文将分别探讨在angular.js和vue.js中如何实现对用户输入的防抖。

angular.js中解决方案

把去抖函数写成一个service,方便多处调用:

.factory('debounce', ['$timeout','$q', function($timeout, $q) {
  // The service is actually this function, which we call with the func
  // that should be debounced and how long to wait in between calls
  return function debounce(func, wait, immediate) {
   var timeout;
   // Create a deferred object that will be resolved when we need to
   // actually call the func
   var deferred = $q.defer();
   return function() {
    var context = this, args = arguments;
    var later = function() {
     timeout = null;
     if(!immediate) {
      deferred.resolve(func.apply(context, args));
      deferred = $q.defer();
     }
    };
    var callNow = immediate && !timeout;
    if ( timeout ) {
     $timeout.cancel(timeout);
    }
    timeout = $timeout(later, wait);
    if (callNow) {
     deferred.resolve(func.apply(context,args));
     deferred = $q.defer();
    }
    return deferred.promise;
   };
  };
 }])

调用方法,在需要使用该功能的controller/directive中注入debounce,也要注入$watch,然后:

$scope.$watch('searchText',debounce(function (newV, oldV) {
  console.log(newV, oldV);
  if (newV !== oldV) {
    $scope.getDatas(newV);
  }
}, 350));

大功告成!

Vue.js中的解决方案

首先在公共函数文件中注册debounce

export function debounce(func, delay) {
 let timer

 return function (...args) {
  if (timer) {
   clearTimeout(timer)
  }
  timer = setTimeout(() => {
   func.apply(this, args)
  }, delay)
 }
}

然后在需要使用的组件中引入debounce,并且在created生命周期内调用:

created() {
 this.$watch('searchText', debounce((newSearchText) => {
  this.getDatas(newSearchText)
 }, 200))
}

大功告成!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 问题 你想只执行某个函数一次,在开始或结束时把多个连续的调用合并成一个简单的操作。 解决方案 使用一个命名函数: debounce: (func, threshold, execAsap) -> timeout = null (args...) -> obj = this delayed = -> func.apply(obj, args) unless exe

  • 问题内容: 对于我正在编写的某些代码,我可以使用Java中的一个不错的通用实现。 当被称为多次毫秒具有相同参数的回调函数应调用一次。 可视化: (某种程度上)这已经在某些Java标准库中存在了吗? 您将如何实施? 问题答案: 请考虑以下线程安全解决方案。请注意,锁定粒度是在密钥级别上的,因此仅同一密钥上的调用会相互阻塞。它还处理在调用call(K)时发生的密钥K过期的情况。

  • 本文向大家介绍JavaScript实现的CRC32函数示例,包括了JavaScript实现的CRC32函数示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript实现的CRC32函数。分享给大家供大家参考,具体如下: 简介: CRC的全称是循环冗余校验。可用于验证数据的完整性。 javascript实现代码如下: 该函数只处理ASCII字符,如需处理中文,需要先编码。 更多

  • 本文向大家介绍vue.js实现请求数据的方法示例,包括了vue.js实现请求数据的方法示例的使用技巧和注意事项,需要的朋友参考一下 vue2.0示例代码如下: vue2.0版本废弃了ready定义的方法,使用mounted来代替,不过需要加上this.$nextTick(function(){}) 。 如果没有请求成功看一下vuejs的版本 1.0版本的写法是这样的 总结 以上就是关于vue.js

  • 问题内容: 在AngularJS中,我可以通过使用ng-model选项来反跳模型。 如何在Angular中对模型进行反跳?我试图在文档中搜索反跳,但找不到任何东西。 一种解决方案是编写我自己的防抖动功​​能,例如: 和我的HTML 但是我正在寻找一个内置函数,Angular中有一个吗? 问题答案: 针对RC.5更新 使用Angular 2,我们可以在窗体控件的可观察对象上使用RxJS运算符进行反跳

  • 本文向大家介绍JS实现数组去重及数组内对象去重功能示例,包括了JS实现数组去重及数组内对象去重功能示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JS实现数组去重及数组内对象去重功能。分享给大家供大家参考,具体如下: 大家在写项目的时候一定遇到过这种逻辑需求,就是给一个数组进行去重处理,还有一种就是给数组内的对象根据某一个属性,比如id,进行去重,下面我写了两个函数,都是可以达到这个效