Vue3 实现一个自带防抖的响应式值 —— CustomRef

前言

写一个防抖函数自然难不倒各位同学。但实现一个自带防抖 的响应式值大家可否听说过,本文使用vue3中的customRef来实现。

基本介绍

customRef 函数可以创建一个自定义ref,并对其依赖项跟踪和更新触发进行控制。该函数接受一个工厂函数作为参数,该工厂函数接收track和trigger两个函数作为参数。

了解过Vue3原理的同学都知道track主要负责get时进行依赖收集,trigger主要负责通知更新

废话不多说,我们直接看如何使用customRef,优雅的实现一个自带防抖的响应式值

例子

js 复制代码
<template>
  {{ value }}
  <input type="text" placeholder="请输入内容..." v-model="value" />
</template>
<script lang="ts" setup>
import { customRef, ref } from "vue";
let time: any = null;
const value = customRef((track, trigger) => {
  let defaultValue = "默认值";
  return {
    get() {
      track();
      return defaultValue;
    },
    set(newValue) {
      clearTimeout(time);
      time = setTimeout(() => {
        defaultValue = newValue;
        console.log("value update");
        trigger();
      }, 500);
    },
  };
});
</script>

上述代码中,我们使用customRef,定义了一个响应式的值,并且使用v-model进行双向绑定。其内部声明了一个闭包变量defaultValueget时调用track进行依赖收集的同时返回,set时修改defaultValue,并调用trigger进行更新,其内部也是利用setTimeOut实现防抖。

输入框进行输入的时候,value只会更新一次。

以上就是customRef实现一个自带防抖的响应式值。当然我们也可以尊重一下CompositionAPI:

js 复制代码
// useDebounceRef.ts
import {customRef} from "vue";
export function useDebounceRef(defaultValue:any,delay = 300){
    let time: any = null;
    return customRef((track, trigger) => {
        return {
          get() {
            track();
            return defaultValue;
          },
          set(newValue) {
            clearTimeout(time);
            time = setTimeout(() => {
              defaultValue = newValue;
              trigger();
            }, 500);
          },
        };
      })
}

// 组件中使用
<template>
  <div>
    {{ value }}
    <input type="text" placeholder="请输入内容..." v-model="value" />
  </div>
</template>
<script lang="ts" setup>
import { useDebounceRef } from "./useDebounceRef";
const value = useDebounceRef("默认值");
</script>
相关推荐
正小安1 小时前
如何在微信小程序中实现分包加载和预下载
前端·微信小程序·小程序
_.Switch3 小时前
Python Web 应用中的 API 网关集成与优化
开发语言·前端·后端·python·架构·log4j
一路向前的月光3 小时前
Vue2中的监听和计算属性的区别
前端·javascript·vue.js
长路 ㅤ   3 小时前
vite学习教程06、vite.config.js配置
前端·vite配置·端口设置·本地开发
长路 ㅤ   3 小时前
vue-live2d看板娘集成方案设计使用教程
前端·javascript·vue.js·live2d
Fan_web3 小时前
jQuery——事件委托
开发语言·前端·javascript·css·jquery
安冬的码畜日常3 小时前
【CSS in Depth 2 精译_044】第七章 响应式设计概述
前端·css·css3·html5·响应式设计·响应式
莹雨潇潇4 小时前
Docker 快速入门(Ubuntu版)
java·前端·docker·容器
Jiaberrr4 小时前
Element UI教程:如何将Radio单选框的圆框改为方框
前端·javascript·vue.js·ui·elementui
Tiffany_Ho5 小时前
【TypeScript】知识点梳理(三)
前端·typescript