Vue3中customRef的用法

customRef作用:

        创建一个自定义的 ref,并对其依赖项跟踪和更新触发进行显式控制。

        如果要使用,记得是在自定义的 ref 中返回一个 customRef,而 customRef 也要返回一个对象

customRef参数:

        customRef的两个参数分别是用于追踪的 track 与用于触发响应的 trigger

代码演示:

        我们通过一个小的功能来体现customRef的用法 在页面输入框中输入文字 1秒后下面h1标签显示最新的数据 类似于防抖的功能 

 

        我们在代码中定义了一个myRef方法并设置了返回值,接着我们声明了一个keyWorld变量通过调用 myRef方法并传递了一个参数 来接收方法的返回值 并将接收到的值返回出去 在模板中使用

<template>
  <div>
    <input type="text" v-model="keyWorld">
    <h1>值是:{{keyWorld}}</h1>
  </div>
</template>

<script>
import { customRef } from "vue";
export default {
  name: "App",
  setup() {
    // 自定义一个ref
    function myRef(value) {
      return customRef((track, trigger) => {
        let timeId
        return {
          get() {
            console.log(value);
            track()    // 通知vue追踪数据的变化
            return value
          },
          set(newValue) {
            console.log(newValue);
            value = newValue
            clearTimeout(timeId)
            timeId = setTimeout(() => {
              trigger()   // 通知Vue去重新解析模板
            }, 1000);
          }
        }
      })
    }
    let keyWorld = myRef("hello")

    // 将数据返回出去
    return {
      keyWorld,
    };
  },
};
</script>


         我们可以看到在方法中返回了customRef的调用  在customRef参数中传递了一个回调函数 在回调函数中我们返回了一个对象 对象中配置了两个方法get和set 这也是customRef方法所规定的 

        customRef的两个参数分别是用于追踪的 track 与用于触发响应的 trigger

        只要是读取了数据就走get方法 修改数据就走set 方法

        我们在get方法里返回了myRef接收到的值 并调用track() 追踪数据的变化  
        我们在set方法里会收到一个最新的值newValue 我们将修改后的最新的值赋值给之前的value 设置定时器 调用trigger() 一秒后通知Vue去重新解析模板

        为了防止每次修改都处触发一个新的定时器 我们在set函数外声明了一个变量来接收定时器返回的id 在下一次修改之后 我们先清除上一次还没有执行的定时器 在调用trigger() 通知Vue去重新解析模板

 

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李公子丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值