<template>
<div>
{{ object }}
<div>
<button @click="changeYesObject">객체o 변경</button>
<button @click="changeNoObject">객체x 변경</button>
</div>
</div>
</template>
<script>
export default {
data() {
return {
object: {
name: "lee",
age: 32,
},
};
},
methods: {
changeYesObject() {
this.object.age = 29;
console.log("객체변경 감지o");
},
changeNoObject() {
this.object.year = 1991;
console.log("객체변경 감지x");
},
},
};
</script>
data:image/s3,"s3://crabby-images/e0606/e0606f632ff37da48c96680317ce8dbe88291035" alt=""
data:image/s3,"s3://crabby-images/c0596/c05964362f04cfc97f7830f1f3d1c62940ef8159" alt=""
해결
<template>
<div>
{{ object }}
<div>
<button @click="changeYesObject1">객체o 변경</button>
<button @click="changeYesObject2">객체o 변경</button>
</div>
</div>
</template>
<script>
export default {
data() {
return {
object: {
name: "lee",
age: 32,
},
};
},
methods: {
changeYesObject1() {
this.$set(this.object, "year", 1991);
console.log("$set 사용 추가완료");
},
changeYesObject2() {
this.object = Object.assign({}, this.object, {
year: 1991,
favoritColor: "purple",
});
console.log("Object.assign() 사용 추가완료");
},
},
};
</script>
data:image/s3,"s3://crabby-images/a00b7/a00b793033374f52b485f09fff512a70d64e279f" alt=""
data:image/s3,"s3://crabby-images/7bf0f/7bf0f9dab29a7bd72b486892976e651e51a63d7f" alt=""