watch监视【reactive】定义的【对象类型】数据

114 阅读1分钟
<script setup lang="ts">
import { reactive, watch } from 'vue'

let person = reactive({ name: '张三', age: 18 })
const changeName = () => {
  person.name += '='
}
const changeAge = () => {
  person.age += 1
}

const changePerson = () => {
  Object.assign(person, { name: '李四', age: 20 })
}

// watch的第一个参数是:被监视的数据
// watch的第二个参数是:监视的回调
// watch的第三个参数是:配置对象()

//监视,情况一:监视reactive定义的对象类型的数据,默认是开启深度监视的,并且是关闭不掉的
//当修改对象中的属性时,newValue和oldValue都是一样的值,因为他们的地址的引用没变
watch(person, (newValue, oldValue) => {
  console.log('新旧值情况一', newValue, oldValue)
})
</script>

<template>
  <div>
    <h1>情况二:监视【reactive】定义的【对象类型】数据</h1>
    <h2>姓名:{{ person.name }}</h2>
    <h2>年龄:{{ person.age }}</h2>
    <button @click="changeName">修改名字</button>
    <button @click="changeAge">修改年龄</button>
    <button @click="changePerson">修改整个人</button>
  </div>
</template>
<style scoped>
button {
  margin: 0 10px;
}
</style>