vue计算属性与watch监听

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue计算属性与watch监听相关的知识,希望对你有一定的参考价值。

参考技术A 总结:

1. 计算属性computed在使用时,一定要注意,函数里面的变量都会被监听,只要里面的某一个值变动,便会将整个函数执行一遍。 而watch只是监听某一个值,若是监听的值里面也有很多变量,也会全部监听

2. 计算后的属性可不在 data 中定义,如果定义会报错,因为对应的computed作为计算属性定义并返回对应的结果给这个变量,变量不可被重复定义和赋值。  而watch监听data中定义的变量变化

computed特性

1.是计算值,

2.应用:就是简化tempalte里面计算和处理props或$emit的传值

3.具有缓存性,页面重新渲染值不变化,计算属性会立即返回之前的计算结果,而不必再次执行函数

watch特性

1.是观察的动作,

2.应用:监听props,$emit或本组件的值执行异步操作

3.无缓存性,页面重新渲染时值不变化也会执行

接下来介绍下 各自的方法:

链接:https://www.jianshu.com/p/d86ae49a5403

Vue--computed计算属性监听数据变化----与watch,methods对比

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script src="./lib/vue-2.4.0.js"></script>
</head>

<body>
  <div id="app">

    <input type="text" v-model="firstname"> +
    <input type="text" v-model="middlename"> +
    <input type="text" v-model="lastname"> =
    <input type="text" v-model="fullname">

    <p> fullname </p>
    <p> fullname </p>
    <p> fullname </p>

  </div>

  <script>
    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue(
      el: #app,
      data: 
        firstname: ‘‘,
        lastname: ‘‘,
        middlename: ‘‘
      ,
      methods: ,
      computed:  // 在 computed 中,可以定义一些 属性,这些属性,叫做 【计算属性】, 计算属性的,本质,就是 一个方法,只不过,我们在使用 这些计算属性的时候,是把 它们的 名称,直接当作 属性来使用的;并不会把 计算属性,当作方法去调用;

        // 注意1: 计算属性,在引用的时候,一定不要加 () 去调用,直接把它 当作 普通 属性去使用就好了;
        // 注意2: 只要 计算属性,这个 function 内部,所用到的 任何 data 中的数据发送了变化,就会 立即重新计算 这个 计算属性的值
        // 注意3: 计算属性的求值结果,会被缓存起来,方便下次直接使用; 如果 计算属性方法中,所以来的任何数据,都没有发生过变化,则,不会重新对 计算属性求值;
        fullname: function () 
          console.log(ok)
          return this.firstname + - + this.middlename + - + this.lastname
        
      
    );
  </script>
</body>

</html>

 

以上是关于vue计算属性与watch监听的主要内容,如果未能解决你的问题,请参考以下文章

vue之watch和计算属性computed

vue3计算属性(computed)与监听(watch)

[每天进步一点点~] vue uni-app 计算属性computed和监听watch

Vue--computed计算属性监听数据变化----与watch,methods对比

06-vue中计算属性computed及监听属性watch

06-vue中计算属性computed及监听属性watch