其实计算属性的get和set是不关联的;get时是跟双向绑定的数据有关,当那个数据变化的时候就触发一下get,更改状态。set时就是处理当改数据变化时,进行的一些处理
<template>
<div>
<h1>hi {{msg}}</h1>
<!-- <div @click="add"> {{count}}</div> -->
<input
type="text"
v-model="val"
>
<button @click="addToDO">add</button>
<ul>
<li
v-for="todo in todos"
:key="todo.title"
>
<input
type="checkbox"
v-model="todo.done"
>
<span>{{todo.title}}</span>
</li>
</ul>
<div>{{doneCount+ '/' + totalTodo}}</div>
<input
type="checkbox"
v-model="allDone"
>
<!-- <div @click="addToDO">addToDO</div> -->
</div>
</template>
<script>
import { defineComponent } from 'vue'
export default defineComponent({
data () {
return {
msg: "vue js",
count: 1,
val: "",
todos: [
{title: "吃饭", done: true},
{title: "睡觉", done: true}
]
}
},
computed: {
doneCount() {
console.log('set时进行了触发1')
return this.todos.filter(item => item.done).length
},
totalTodo() {
return this.todos.length
},
allDone: {
get() {
console.log("set时进行了触发")
return this.doneCount === this.todos.length
},
set(val) {
this.todos.forEach(item => item.done = val)
}
}
},
methods: {
add () {
this.count++
},
addToDO() {
if(!this.val) {
alert('必须填内容')
return
}
this.todos.push({title:this.val,done:false})
this.val = ""
}
},
})
</script>
<style>
</style>
控制台的打印:
set时进行了触发1
App.vue:54 set时进行了触发