Vue侦听器

Vue侦听器是根据组件状态做DOM更新或者异步更新其他级联状态的。计算属性的主要目标是根据已有数据计算出组件的状态,它是组件内部的计算,计算结果在组件内部应用。侦听器的主要目标是根据组件状态的变动,做级联的或者异步的操作或DOM更新,操作的影响范围比计算属性大得多。

javascript 复制代码
<script setup lang="ts">
import {reactive, ref, watch} from "vue"

   const obj=reactive({name:"obj",count:0});
   
   // count is formal parameter, it's change will not saved to obj.count
   watch(()=>obj.count,(count)=>{
      count=count+3;
      console.log("watch by obj.count by getter :"+count);
   });

   // obj is real parameter , it's change will be saved to obj
   watch(obj,(oldValue,newValue)=>{
       console.log("watch by obj by deep way :"+newValue.count);
   });

   watch(name,(oldName,newName)=>{
        console.log("oldName is "+oldName+", newName is "+newName);
   });

</script>

<template>
      <div>
            <button type="button" @click="obj.count++">测试侦听器</button>
      </div>
</template>

<style>

</style>

侦听器的标准格式如下:

javascript 复制代码
const data=ref({});

watch(data,(oldValue,newValue)=>{
      console.log(oldValue);
      console.log(newValue);
   },{
      immediate:true,  //default value is false, true value means watch callback function will be called immediately
      deep:true,    //default value is false, true value means watch is a deep watch
      flush:"post"   //default value is "pre", "post" means watch callback function can fetch data after Vue DOM updated completely
   });

侦听器默认情况下是懒执行、浅层侦听、在Vue组件更新之前被调用的。

相关推荐
朱穆朗8 分钟前
electron升级到33.0.x版本后,devtools字体的修改方法
前端·javascript·electron
2501_9444522314 分钟前
智能洞察 Cordova 与 OpenHarmony 混合开发实战
javascript
IT_陈寒17 分钟前
Java 21新特性实战:5个必学的性能优化技巧让你的应用提速40%
前端·人工智能·后端
Irene199121 分钟前
insertAdjacentHTML() 详解
javascript·dom
HarrySunCn21 分钟前
大夏龙雀DX-CT511N-B实战之路-第1步
前端·单片机·物联网·iot
未来之窗软件服务30 分钟前
幽冥大陆(七十七)C# 调用 中文huayan-medium.onnx —东方仙盟练气期
前端·ui·c#·仙盟创梦ide·东方仙盟
古茗前端团队31 分钟前
用 NAudio 做一个音频播放器及原理
前端
成为大佬先秃头32 分钟前
渐进式JavaScript框架:Vue 工具 & 模块化 & 迁移
开发语言·javascript·vue.js
xiaoxue..33 分钟前
二叉搜索树 BST 三板斧:查、插、删的底层逻辑
javascript·数据结构·算法·面试
wei yun liang37 分钟前
4.数据类型
前端·javascript·css3