Vue3中customRef的用法
作用:创建一个自定义的 ref,并对其依赖项跟踪和更新触发进行显式控制。<template><div><input type="text" v-model="keyWorld"><h1>值是:{{keyWorld}}</h1></div></template><script>import { custo
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去重新解析模板

更多推荐
 


所有评论(0)