Vue 创建自定义 ref 函数

简介: Vue 创建自定义 ref 函数
Vue 创建自定义 ref 函数 customRef

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

使用 customRef 创建自定义 ref 函数
// 创建自定义 ref 函数
function myRef(value) {
    return customRef((track, trigger) => {
        return {
            get() {
                track(); // 通知 Vue 追踪 value 的变化
                return value; // 返回 value 值
            },
            set(newValue) {
                value = newValue; // 修改 value 值
                trigger(); // 通知 Vue 重新解析模板
            }
        }
    })
}
// 使用自定义 ref 函数
let content = myRef('测试鸭');
自定义 ref 实现防抖效果:
<template>
    <input type="text" v-model="keyWord">
    <h3>{{ keyWord }}</h3>
</template>
<script>
import { customRef } from 'vue';
export default {
    name: "Home",
    setup() {
        // 自定义一个 ref 函数,名为:myRef
        function myRef(value, delay) {
            let timer = null;
            return customRef((track, trigger) => {
                return {
                    get() {
                        console.log('有人读取了数据', value);
                        track(); // 通知 Vue 追踪 value 的变化
                        return value; // 返回 value 值
                    },
                    set(newValue) {
                        clearTimeout(timer); // 清除上一次的延时执行
                        // 延时执行修改数据
                        timer = setTimeout(() => {
                            console.log('有人修改了数据', newValue);
                            value = newValue; // 修改 value 值
                            trigger(); // 通知 Vue 重新解析模板
                        }, delay)
                    }
                }
            })
        }
        let keyWord = myRef('你好呀', 500);
        // 返回数据
        return { keyWord }
    }
}
</script>
相关文章
|
1天前
|
JavaScript
Vue实战-组件通信
Vue实战-组件通信
4 0
|
1天前
|
JavaScript
Vue实战-将通用组件注册为全局组件
Vue实战-将通用组件注册为全局组件
5 0
|
1天前
|
JavaScript 前端开发
vue的论坛管理模块-文章评论02
vue的论坛管理模块-文章评论02
|
2天前
|
存储 JavaScript
Vue当前时间与接口返回时间的判断
Vue当前时间与接口返回时间的判断
8 0
|
2天前
|
JavaScript 前端开发
Vue生成Canvas二维码
Vue生成Canvas二维码
7 0
|
2天前
|
JavaScript 前端开发 开发者
new Vue() 发生了什么
new Vue() 发生了什么
9 1
|
2天前
|
JavaScript
Vue 中如何模块化使用 Vuex
Vue 中如何模块化使用 Vuex
6 0
|
1天前
|
JavaScript Java
vue的论坛管理模块-文章查看-01
vue的论坛管理模块-文章查看-01
|
1天前
|
JavaScript
vue页面加载时同时请求两个接口
vue页面加载时同时请求两个接口
|
1天前
|
JavaScript
vue里样式不起作用的方法,可以通过deep穿透的方式
vue里样式不起作用的方法,可以通过deep穿透的方式