Vue学习笔记-Vue3中的customRef

作用

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

案例

描述:向输入框中输入内容,在下方延迟1秒展示输入内容

代码:

javascript 复制代码
<template>
  <input type="text" v-model="keyword">
  <h3>{{keyword}}</h3>
</template>

<script>
import {customRef} from 'vue'
export default {
  name: 'App',
  setup(){
    function  myRef(value){
      return customRef((track, trigger)=>{
        let timer
          return{
            get(){
              console.log('正在读取数据...:',value)
              //通知vue追踪value的变化
              track();
              return value
            },
            set(newValue){
              console.log('数据发生改变,新数据为:',newValue)
              clearTimeout(timer)
              // //将新值赋给value
              // value = newValue;
              // //通知vue重新解析模板
              // trigger();
              timer = setTimeout(()=>{
                value = newValue;
                trigger();
              },1000)
            }
          }
      })
    }
    //写一个自定义的myRef
    let keyword = myRef('hello')
    return{
      keyword
    }
  },
}
</script>

<style>

</style>
相关推荐
知识分享小能手10 分钟前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019 游标 — 语法知识点及使用方法详解(14)
数据库·学习·sqlserver
强子感冒了12 分钟前
JavaScript学习笔记:函数、方法与继承(原型与class)
javascript·笔记·学习
寒秋花开曾相惜13 分钟前
(学习笔记)第2章 信息的表示和处理
笔记·学习
curry____30321 分钟前
c++位运算符笔记
java·c++·笔记
打瞌睡的朱尤9 小时前
Vue day10 完整购物网页(登录页,首页,搜索)
前端·javascript·vue.js
瞎某某Blinder10 小时前
DFT学习记录[4] 电子和空穴的有效质量计算全流程
python·学习
扶苏100210 小时前
深入理解 Vue 3 的 watchEffect
前端·javascript·vue.js
zhangfeng113311 小时前
Warmup Scheduler深度学习训练中,在训练初期使用较低学习率进行预热(Warmup),然后再按照预定策略(如余弦退火、阶梯下降等)衰减学习率的方法
人工智能·深度学习·学习
日更嵌入式的打工仔11 小时前
LAN9253中文注释第七章
笔记·原文翻译
red_redemption13 小时前
自由学习记录(118)
学习