其实计算属性的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>
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
  • 56.
  • 57.
  • 58.
  • 59.
  • 60.
  • 61.
  • 62.
  • 63.
  • 64.
  • 65.
  • 66.
  • 67.
  • 68.
  • 69.
  • 70.
  • 71.
  • 72.
  • 73.
  • 74.
  • 75.
  • 76.
  • 77.
  • 78.

控制台的打印:

set时进行了触发1
App.vue:54 set时进行了触发