Vue3:自定义响应式数据-customRef(面试常问,重点!!!)

一、情景说明

我们知道,Vue的响应式数据效果就是,页面和变量的关联效果

页面一修改变量值,引用变量的地方就会同时更新

那么,假设我们有这样一个需求,就是,让响应式变量在页面修改后,过2秒,才进行更新展示

这个事后,就要用到customRef来实现功能

二、案例

hooks写法

javascript 复制代码
import { customRef } from "vue";

export default function(initValue:string,delay:number){
  // 使用Vue提供的customRef定义响应式数据
  let timer:number
  // track(跟踪)、trigger(触发)
  let msg = customRef((track,trigger)=>{
    return {
      // get何时调用?------ msg被读取时
      get(){
        track() //告诉Vue数据msg很重要,你要对msg进行持续关注,一旦msg变化就去更新
        return initValue
      },
      // set何时调用?------ msg被修改时
      set(value){
        clearTimeout(timer)
        timer = setTimeout(() => {
          initValue = value
          trigger() //通知Vue一下数据msg变化了
        }, delay);
      }
    }
  })
  return {msg}
}

重点分析

1、customRef的基本结构

javascript 复制代码
const initValue
customRef((track,trigger)=>{
    return {
      get(){
        track() // 告诉Vue数据msg很重要,要对msg持续关注,一旦变化就更新
        return initValue
      },
      set(value){
          initValue = value
          trigger() //通知Vue数据msg变化了
      }
    }
  }) 

2、track,trigger参数

我们会发现
track要在get函数业务逻辑的第一行
trigger要在set函数业务逻辑的最后一行

它们的作用类似订阅与发布,是对数据的一种监视!

这样,才能实现数据的响应式

比喻理解:

ref是直接去4S车店买车,一手交钱一手交货

customRef,是去工厂定制一辆车:造车

track就是订购人,要实时跟踪造车的过程,相当于监工

trigger就是造车的技术员,造好了通知一下购车人

3、延迟更新展示

主要是在set函数里面,用到了定时器

但是,这里会发现,结合了clearTimeout一起使用

这样,是为了防止,快速输入,导致set频繁调用出现的bug

相关推荐
键盘鼓手苏苏37 分钟前
Flutter for OpenHarmony:markdown 纯 Dart 解析引擎(将文本转化为结构化 HTML/UI) 深度解析与鸿蒙适配指南
前端·网络·算法·flutter·ui·html·harmonyos
芭拉拉小魔仙7 小时前
企业级Vue项目的状态管理:从原理到实战架构
前端·vue.js·架构
恋猫de小郭7 小时前
丰田正在使用 Flutter 开发游戏引擎 Fluorite
android·前端·flutter
扶苏10027 小时前
Vue 3 响应式原理深度解析
前端·javascript·vue.js
NEXT067 小时前
React 性能优化:图片懒加载
前端·react.js·面试
PineappleCoder8 小时前
别让字体拖了后腿:FOIT/FOUT 深度解析与字体加载优化全攻略
前端·性能优化
NEXT068 小时前
后端跑路了怎么办?前端工程师用 Mock.js 自救实录
前端·后端·程序员
装不满的克莱因瓶9 小时前
Java7新特性:try-with-resources写法
java·前端·javascript·jdk·新特性·jdk7
SailingCoder11 小时前
【 从“打补丁“到“换思路“ 】一次企业级 AI Agent 的架构拐点
大数据·前端·人工智能·面试·架构·agent
~央千澈~11 小时前
抖音弹幕游戏开发之第12集:添加冷却时间机制·优雅草云桧·卓伊凡
java·服务器·前端