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>

效果:输入内容等待500毫秒后,页面才会更新。


相关文章
|
1天前
|
JavaScript 前端开发 API
技术好文:vue混入(mixin)的使用
技术好文:vue混入(mixin)的使用
|
1天前
|
移动开发 JavaScript 程序员
程序员必知:vue播放video插件vue
程序员必知:vue播放video插件vue
|
1天前
|
JavaScript 程序员
程序员必知:vue中按钮使用v
程序员必知:vue中按钮使用v
|
1天前
|
JavaScript
Vue学习系列(二)——组件详解
Vue学习系列(二)——组件详解
|
1天前
|
JSON 资源调度 JavaScript
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
1005 0
|
1天前
|
JavaScript 前端开发
Vue组件生命周期深度剖析:从创建到销毁的八大钩子实战指南
Vue组件生命周期深度剖析:从创建到销毁的八大钩子实战指南
|
2天前
|
分布式计算 资源调度 JavaScript
程序员必知:vue项目创建和启动、ElementUI的安装和快速学习
程序员必知:vue项目创建和启动、ElementUI的安装和快速学习
|
2天前
|
JavaScript
vue基础概念(1)
vue基础概念(1)
6 0
|
2天前
|
JavaScript
vue父子组件传值,父组件内容更新子组件内容不实时更新
vue父子组件传值,父组件内容更新子组件内容不实时更新
8 0