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. bzoj5090 [Lydsy1711月赛]组题 分数规划

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=5090 题解 令 \(s_i\) 表示 \(a_i\) 的前缀和. 那么平均难度系数就是 \[ ...

  2. Azure IoT 技术研究系列2

    上篇博文中,我们主要介绍了Azure IoT Hub的基本概念.架构.特性: Azure IoT 技术研究系列1-入门篇 本文中,我们继续深入研究,做一个起步示例程序:模拟设备注册到Azure IoT ...

  3. js设置定时器在规定的日期内替换掉页面

    <script type="text/javascript"> window.onload=function(){ var myspan=document.getEle ...

  4. 【转载】MIMO技术杂谈(一):鱼与熊掌能否兼得?--浅谈分集与复用的权衡

    原文链接(向作者致敬):http://www.txrjy.com/thread-667901-1-1.html   无线通信世界在过去的几十年中的发展简直是爆发式的,MIMO(多发多收)技术的出现更是 ...

  5. 利用BeautifulSoup爬去我爱我家的租房数据

    因为之前对BeautifulSoup一直不是很熟悉,刚好身边的朋友同事在找房子,就想着能不能自己写个爬虫爬一下数据,因此就写了这个爬虫.基本都是边看书边写的,不过也没什么好讲的.直接粘代码了. # c ...

  6. react native 之 在现有的iOS工程中集成react native

    在现有的iOS工程中集成react native, 或者说将react native引入到iOS 项目,是RN和iOS混合开发的必经之路 参考官网教程:https://reactnative.cn/d ...

  7. mybatis配eclise模板,mybatis快速生成模板

    eclipse中mybatis得mapper文件不提示(mybatis-3-mapper.dtd,mybatis-3-config.dtd) 1.下载该文件到你的硬盘文件夹下 2.windows -- ...

  8. HDU - 5306 Gorgeous Sequence 线段树 + 均摊分析

    Code: #include<algorithm> #include<cstdio> #include<cstring> #define ll long long ...

  9. Java——动态绑定和多态

    动态绑定是在执行期间(而不是编译期间)判断所用对象的实际类型,根据其实际的类型调用其相应的方法(确定选择哪个多态形式被调用). 首先是方法的参数是父类对象,传入子类对象是否可行 然后引出Parent ...

  10. 【bzoj3566】 [SHOI2014]概率充电器

    *题目描述: 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器: “采用全新纳米级加工技术,实现元件与导线能否通电完全由真随机数决定!SHOI 概率充电器,您生活不可 ...