目录
  • computed
    • 注意
    • 应用场景
  • watch
    • 总结

      computed

      computed 看上去是方法,但是实际上是计算属性,它会根据你所依赖的数据动态显示新的计算结果。计算结果会被缓存,computed 的值在 getter 执行后是会缓存的,只有在它依赖的属性值改变之后,下一次获取 computed 的值时才会重新调用对应的 getter 来计算。

      1)下面是一个比较经典简单的案例

      <template>
        <div class="hello">
            {{fullName}}
        </div>
      </template>
      
      <script>
      export default {
          data() {
              return {
                  firstName: '飞',
                  lastName: "旋"
              }
          },
          props: {
            msg: String
          },
          computed: {
              fullName() {
                  return this.firstName + ' ' + this.lastName
              }
          }
      }
      </script>

      注意

      在 Vue 的 template 模板内({{}})是可以写一些简单的js表达式的很便利,如上直接计算 {{this.firstName + ' ' + this.lastName}},因为在模版中放入太多声明式的逻辑会让模板本身过重,尤其当在页面中使用大量复杂的逻辑表达式处理数据时,会对页面的可维护性造成很大的影响,而 computed 的设计初衷也正是用于解决此类问题。

      应用场景

      适用于重新计算比较费时不用重复数据计算的环境。所有 getter 和 setter 的 this 上下文自动地绑定为 Vue 实例。如果一个数据依赖于其他数据,那么把这个数据设计为 computed

      watch

      watcher 更像是一个 data 的数据监听回调,当依赖的 data 的数据变化,执行回调,在方法中会传入 newVal 和 oldVal。可以提供输入值无效,提供中间值 特场景。Vue 实例将会在实例化时调用 $watch(),遍历 watch 对象的每一个属性。如果你需要在某个数据变化时做一些事情,使用watch。

      <template>
        <div class="hello">
            {{fullName}}
            <button @click="setNameFun">click</button>
        </div>
      </template>
      
      <script>
      export default {
          data() {
              return {
                  firstName: '飞',
                  lastName: "旋"
              }
          },
          props: {
            msg: String
          },
          methods: {
              setNameFun() {
                  this.firstName = "大";
                  this.lastName = "熊"
              }
          },
          computed: {
              fullName() {
                  return this.firstName + ' ' + this.lastName
              }
          },
          watch: {
              firstName(newval,oldval) {
                console.log(newval)
                console.log(oldval)
              }
          }
      }
      </script>

      总结

      • 1.如果一个数据依赖于其他数据,那么把这个数据设计为 computed
      • 2.如果你需要在某个数据变化时做一些事情,使用 watch 来观察这个数据变化
      声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。