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. Zabbix--05 Grafana、percona、自动发现和自动注册

    目录 一. Grafana自定义图形 1.安装grafana 2.安装并激活zabbix插件 3.数据展示 4.自定义图形仪表盘 5.自定义图形饼图 二. percona模版监控mysql 1.安装p ...

  2. 《Java核心技术卷I》——第3章 Java的基本程序设计结构

    byte和short类型主要用于特定的应用场合,例如,底层的文件处理或者需要控制占用存储空间量的大数组. 十六进制数值有一个前缀0x(如0xCAFE),八进制有一个前缀0,如010对应八进制中的8.很 ...

  3. PAT Advanced 1035 Password (20 分)

    To prepare for PAT, the judge sometimes has to generate random passwords for the users. The problem ...

  4. 牛客练习赛33 B tokitsukaze and RPG (类埃筛)

    链接:https://ac.nowcoder.com/acm/contest/308/B 来源:牛客网 tokitsukaze and RPG 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/ ...

  5. Insomni'hack teaser 2019 - Reverse - beginner_reverse

    参考链接 https://ctftime.org/task/7455 题目描述 A babyrust to become a hardcore reverser 点我下载 解题过程 一道用rust写的 ...

  6. React Autocomplete(自动完成输入)示例教程

    React Autocomplete示例教程是今天的主题.在现代Web开发中,使用React改善用户体验是很容易.自动完成的概念很简单.它是基于用户输入的建议列表.然后,用户可以按Enter键以完成短 ...

  7. 【长期计划】Atcoder题目泛做

    之前学长跟我说的是700-的应该都能自己做? 然后1000-的应该都能有一定的思路? 记不清了 但总之是要智力康复一下 又加上文化课比较紧 所以这个大概就会是长期计划了 ————————————分鸽线 ...

  8. jQuery 遍历 - 同胞(siblings)

    同胞拥有相同的父元素. 通过 jQuery,您能够在 DOM 树中遍历元素的同胞元素. 在 DOM 树中水平遍历 有许多有用的方法让我们在 DOM 树进行水平遍历: siblings() next() ...

  9. Spring——IOC与Bean容器

    [IOC] (1)IOC:控制反转,控制权的转移,应用程序本身不负责依赖对象的创建和维护,而是由外部容器负责创建和维护.也就是说由IOC容器在运行期间,动态地将某种依赖关系注入到对象之中 (2)DI: ...

  10. Leetcode 14. Longest Common Prefix(水)

    14. Longest Common Prefix Easy Write a function to find the longest common prefix string amongst an ...