1、什么是计算属性

  • 如果模板中的表达式存在过多的逻辑,那么模板会变得臃肿不堪,维护起来也异常困难,因此为了简化逻辑出现了计算属性;

    <template>
    <div id="example">
    <p>{{message.split(" ").reverse().join('!')}}</p>
    </div>
    </template>
    <script>
    export default {
    name: "example",
    data() {
    return {
    message : 'i am chinese person'
    };
    },
    methods : { },
    mounted(){ }
    };
    </script>

    上述表达式比较繁琐,因此我们采用计算属性实现

  • 特点:在一个计算属性里可以完成各种复杂的逻辑,包括运算、函数调用等,只要最终返回一个结果就可以;
    <template>
    <div id="example">
    <p>源数据:{{message}}</p>
    <p>更改后的数据:{{changeMessage}}</p>
    </div>
    </template>
    <script>
    export default {
    name: "example",
    data() {
    return {
    message : 'i am chinese person'
    };
    },
    computed : {
    //getter方法
    changeMessage : function(){//无需进行声明
    return this.message.split(" ").reverse().join('!')
    }
    }
    };
    </script>

    结果为:

  • 计算属性拥有的两个方法:getter   setter   用来实现数据的双向绑定

    <template>
    <div id="example">
    <p>给定以下三个词语组成一句话</p>
    <span>{{combine}}</span>&nbsp;&nbsp;&nbsp;&nbsp;
    <span>{{mom}}</span>&nbsp;&nbsp;&nbsp;&nbsp;
    <span>{{dad}}</span>&nbsp;&nbsp;&nbsp;&nbsp;
    <p style="padding:12px 0">答案为:{{result}}</p>
    <button @click="btn">改变语句</button>
    </div>
    </template>
    <script>
    export default {
    name: "example",
    data() {
    return {
    mom: "妈妈",
    dad: "爸爸",
    combine: "组成了一个家"
    };
    },
    computed: {
    result : {//与不写get set方法的形式有区别
    //一个计算属性的getter
    get : function(){//三个值变化的时候,result的值会自动更新,也会自动更新DOM结构
    return this.mom + this.dad + this.combine
    },
    // 一个计算属性的setter
    set : function(newVal){//当设置result的时候,其他的值也会相应的发生改变
    this.mom = newVal.substr(0,2);
    this.dad = newVal.substr(2,2);
    this.combine = newVal.substr(4)
    }
    }
    },
    methods : {
    btn(){
    this.result = "医生警察为人民服务"
    }
    }
    };
    </script>

    首次渲染结果为:

      点击按钮结果为:

 2、计算属性缓存(最大的特点)-----属性变化才执行getter函数,否则使用缓存  默认为true使用缓存

  • 作用:如果频繁的使用计算属性,而计算属性方法中有大量的耗时操作(例如getter中循环一个大的数组以执行很多操作),会带来一些性能问题;

    <template>
    <div id="example">
    <p>给定以下三个词语组成一句话</p>
    <span>{{combine}}</span>&nbsp;&nbsp;&nbsp;&nbsp;
    <span>{{mom}}</span>&nbsp;&nbsp;&nbsp;&nbsp;
    <span>{{dad}}</span>&nbsp;&nbsp;&nbsp;&nbsp;
    <p style="padding:12px 0">答案为:{{result}}</p>
    <button @click="btn">改变语句</button>
    </div>
    </template>
    <script>
    export default {
    name: "example",
    data() {
    return {
    mom: "妈妈",
    dad: "爸爸",
    combine: "组成了一个家"
    };
    },
    computed: {
    result : {//与不写get set方法的形式有区别
    //一个计算属性的getter
    cache: true,//打开缓存
    get : function(){//三个值变化的时候,result的值会自动更新,也会自动更新DOM结构
    return new Date().getTime() + this.mom + this.dad + this.combine
    },
    // 一个计算属性的setter
    set : function(newVal){//当设置result的时候,其他的值也会相应的发生改变
    this.mom = newVal.substr(0,2);
    this.dad = newVal.substr(2,2);
    this.combine = newVal.substr(4)
    }
    }
    },
    methods : {
    btn(){
    this.result = "医生警察为人民服务"
    }
    }
    };
    </script>

3、使用过程中遇到的问题

  • 计算属性getter不执行的场景

    • 当包含计算属性的节点被移除并且模板当中其他地方没有在引用该属性时,对应的getter不会再执行;

      <template>
      <div id="example">
      <button @click="btn">总价格的显示隐藏</button>
      <p v-if="showTotal">总价格是:{{totalPrice}}</p>
      </div>
      </template>
      <script>
      export default {
      name: "example",
      data() {
      return {
      showTotal : true,
      basePrice : 100,
      };
      },
      computed: {
      totalPrice : {
      get : function(){
      return this.basePrice * 99
      }
      }
      },
      methods: {
      btn(){
      this.showTotal = !this.showTotal
      }
      }
      };
      </script>

      在本程序中,p元素移除后,计算属性在别的地方不会再被使用,因此getter方法不会被执行;若每次都不执行,请加入缓存cache:false

    • 当节点移除,其他地方使用计算属性时:
      <template>
      <div id="example">
      <p>{{totalPrice}}</p>
      <button @click="btn">总价格的显示隐藏</button>
      <p v-if="showTotal">总价格是:{{totalPrice}}</p>
      </div>
      </template>
      <script>
      export default {
      name: "example",
      data() {
      return {
      showTotal : true,
      basePrice : 100,
      };
      },
      computed: {
      totalPrice : {
      cache : false,
      get : function(){
      console.log(1)
      return this.basePrice * 99
      }
      }
      },
      methods: {
      btn(){
      this.showTotal = !this.showTotal
      }
      }
      };
      </script>

      每次都执行getter

简述Vue中的计算属性的更多相关文章

  1. Vue学习之vue中的计算属性和侦听器

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. Vue中的计算属性与$watch

    计算属性:在模板中绑定表达式是非常便利的,但是他们实际上只用于简单的操作.模板是为了描述视图的结构.在模板中放入太多的逻辑会让模板过重且难以维护.这就是为什么vue.js将绑定表达式限制为一个表达式. ...

  3. Vue中的计算属性和监听器(computed 与 watch)

    react中数据是单向绑定的,而vue中数据是双向绑定的.为什么? 在react中,主要是通过setState 去改变state的值:而在vue中,会自动的触发set 与get 改变属性的值. 在vu ...

  4. 浅谈vue中的计算属性和侦听属性

    计算属性 计算属性用于处理复杂的业务逻辑 计算属性具有依赖性,计算属性依赖 data中的初始值,只有当初始值改变的时候,计算属性才会再次计算 计算属性一般书写为一个函数,返回了一个值,这个值具有依赖性 ...

  5. 怎样理解 Vue 中的计算属性 computed 和 methods ?

    需求: 在 Vue 中, 我们可以像下面这样通过在 引号 或 双花括号 内写 js 表达式去做一些简单运算, 这是可以的, 不过这样写是不直观的, 而且在 html 中 夹杂 一些运算逻辑这种做法其实 ...

  6. Vue中computed(计算属性)、methods、watch的区别

    实现效果:字符串的动态拼接 methods方法 html: <div id="app"> <!-- 监听到文本框数据的改变 --> <input ty ...

  7. Vue中的计算属性

    一.什么是计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护. 二.计算属性的用法 在一个计算属性里可以完成各种复杂的逻辑,包括运算.函 ...

  8. Vue中computed计算属性

    话不多说,使用方法直接上代码//在模板中调用computedTest这个函数,切记不要在函数后添加()<template> <div class="home"&g ...

  9. vue中computed计算属性与methods对象中的this指针

    this 指针问题 methods与computed中的this指针 应该指向的是它们自己,可是为什么this指针却可以访问data对象中的成员呢? 因为new Vue对象实例化后data中的成员和c ...

随机推荐

  1. docker持久化之存储卷

         启动时敲:   docker run -it -v /var/mydata:/abc myos   #前面写真实机里的文件夹,冒号后面写docker里面的文件夹,最后写镜像名 (可以同时挂载 ...

  2. 手写与copy

    m_Font.CreateFont( 14, // 字体高度 0 , // 宽度由系统确定 0 , // 文本不倾斜 0 , // 字体不倾斜 FW_NORMAL, // 字体粗度 0 , // 非斜 ...

  3. Proxy + Reflect 实现 响应的数据变化

    Proxy 对象用于定义基本操作的自定义行为(如属性查找,赋值,枚举,函数调用等) let p = new Proxy(target, handler); get(target, propKey, r ...

  4. Arduino库

    单总线库: 下载地址  :  链接:https://pan.baidu.com/s/1YSuqrXWuBAxMEUWHy8rckw    提取码:svix 把整个文件夹复制到 Arduino安装目录的 ...

  5. 粘性固定 position:sticky

    在研究rem布局时,无意中看到网易新闻移动端首页的导航栏用上了一个CSS 3的属性粘性定位position:sticky,它是相对定位(position:relative)和固定定位(position ...

  6. Git整理[1] git cherry-pick的使用

    简单地说 git cherry-pick为”挑拣”提交 ,挑取某次提交合并到其他分支上,而不用合并整个分支. 参数: git cherry-pick [<options>] <com ...

  7. LeetCode 1143 最长公共子序列

    链接:https://leetcode-cn.com/problems/longest-common-subsequence 给定两个字符串 text1 和 text2,返回这两个字符串的最长公共子序 ...

  8. 使用AnnotationConfigApplicationContext注册配置类

    1. AnnotationConfigApplicationContext功能 该类可以实现基于Java的配置类加载自定义在Spring的应用上下文的bean. 1.1 使用方式一:在构造方法中完成注 ...

  9. linux运维、架构之路-实时同步方案

    一.inotify+rsync实时同步 1.介绍         inotify-tools是一种强大的.细粒度的.异步的文件系统事件监控机制,可以用来监控文件系统的事件.inotify-tools是 ...

  10. mysql CHECK约束 语法

    mysql CHECK约束 语法 作用:CHECK 约束用于限制列中的值的范围. 直线电机 说明:如果对单个列定义 CHECK 约束,那么该列只允许特定的值.如果对一个表定义 CHECK 约束,那么此 ...