<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <div id="app"> <input type="text" v-model="info.username"> <input type="text" v-model="info.address.city"> </div> <script src="./lib/vue-2.6.12.js"></script> <script src="./lib/jquery-v3.6.0.js"></script> <script> const vm = new Vue({ el: '#app', data: { // 用户的信息对象 info: { username: 'admin', address: { city: '北京' } } }, // 所有的侦听器,都应该被定义到 watch 节点下 watch: { info: { handler(newVal) { console.log(newVal) }, // 开启深度监听,只要对象中任何一个属性变化了,都会触发“对象的侦听器” deep: true } // 如果要侦听的是对象的子属性的变化,则必须包裹一层单引号 // 'info.username'(newVal) { // console.log(newVal) // } } }) </script> </body> </html>
直接给deep属性设置为true