0
点赞
收藏
分享

微信扫一扫

5、计算属性的使用


其实计算属性的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时进行了触发


举报

相关推荐

0 条评论