vue3中使用watch

Vue 3 中 watch 的详细使用指南

在 Vue 3 中,watch 是一个用于观察和响应数据变化的强大 API。下面是关于 Vue 3 中 watch 的详细使用说明。

1.基本用法,观察单个ref数据

javascript 复制代码
import { ref, watch } from 'vue'

export default {
  setup() {
    const count = ref(0)
    
    // 基本 watch 用法
    watch(count, (newValue, oldValue) => {
      console.log(`count 从 ${oldValue} 变为 ${newValue}`)
    })
    
    return {
      count
    }
  }
}

2. 观察响应式对象

javascript 复制代码
import { reactive, watch } from 'vue'

export default {
  setup() {
    const state = reactive({
      count: 0,
      name: 'John'
    })
    
    // 观察整个响应式对象
    watch(() => state, (newState, oldState) => {
      console.log('state changed', newState)
    }, { deep: true })
    
    // 观察特定属性
    watch(() => state.count, (newCount, oldCount) => {
      console.log(`count changed: ${oldCount} -> ${newCount}`)
    })
    
    return {
      state
    }
  }
}

3.观察多个源

javascript 复制代码
import { ref, watch } from 'vue'

export default {
  setup() {
    const count = ref(0)
    const name = ref('John')
    
    watch([count, name], ([newCount, newName], [oldCount, oldName]) => {
      console.log(`count: ${oldCount} -> ${newCount}`)
      console.log(`name: ${oldName} -> ${newName}`)
    })
    
    return {
      count,
      name
    }
  }
}

4.常用高级选项

4.1. deep 选项

当观察对象或数组时,需要使用 deep 选项来深度观察嵌套属性的变化。

javascript 复制代码
import { reactive, watch } from 'vue'

export default {
  setup() {
    const user = reactive({
      name: 'John',
      address: {
        city: 'New York'
      }
    })
    
    watch(user, (newValue, oldValue) => {
      console.log('user changed', newValue)
    }, { deep: true })
    
    return {
      user
    }
  }
}

4.2 immediate 选项

immediate 选项使回调在观察开始时立即执行。

javascript 复制代码
import { ref, watch } from 'vue'

export default {
  setup() {
    const count = ref(0)
    
    watch(count, (newValue, oldValue) => {
      console.log(`count is ${newValue}`)
    }, { immediate: true })
    
    return {
      count
    }
  }
}

5. vue3官网解释

更多详情请访问vue3官网

相关推荐
盗德几秒前
Vue渲染引擎的范式革命:从虚拟DOM到Vapor模式
前端·vue.js
BUG收容所所长1 分钟前
React递归渲染与react-dnd——低代码平台的组件拖拽与动态渲染实践
前端·javascript·设计
阿华的代码王国17 分钟前
【Android】日期选择器
android·xml·java·前端·后端
张拭心1 小时前
拭心 7 月日复盘|个体在 AI 时代的挑战
前端
这是个栗子1 小时前
express-jwt报错:Error: algorithms should be set
前端·npm·node.js
Dolphin_海豚1 小时前
vapor 的 IR 是如何被 generate 到 render 函数的
前端·vue.js·vapor
小妖6661 小时前
Next.js 怎么使用 Chakra UI
前端·javascript·ui
胡西风_foxww1 小时前
从数据丢失到动画流畅:React状态同步与远程数据加载全解析
前端·javascript·react.js·同步·异步·数据·状态
格调UI成品1 小时前
[特殊字符] 数据可视化结合 three.js:让 3D 呈现更精准,3 个优化经验谈
javascript·3d·信息可视化
初遇你时动了情2 小时前
JS中defineProperty/Proxy 数据劫持 vue3/vue2双向绑定实现原理,react 实现原理
javascript·vue.js·react.js