计算属性

在模板表达式中放入太多逻辑时,会让模板重且难以维护。比如:

// 错误示例
<div id="example">{{ message.split('').reverse().join('') }}
</div>

应该声明一个计算属性,该计算属性不用挂载到Vue实例的data上,而是在Vue实例中的computed上。程序员编写的函数将作用与 property.vm.reversedMessage 的 getter函数

具体看https://cn.vuejs.org/v2/guide/computed.html#%E8%AE%A1%E7%AE%97%E5%B1%9E%E6%80%A7

计算属性缓存 VS 方法

  1. 相同点:同一个函数定义为方法或计算属性,两种方式的最终结果完全相同。
  2. 不同点:计算属性是基于它们的响应式依赖进行缓存的。

具体看https://cn.vuejs.org/v2/guide/computed.html#%E8%AE%A1%E7%AE%97%E5%B1%9E%E6%80%A7

计算属性 VS 侦听属性

  1. 当有些数据需要随着其他数据变动而变动时,可以使用侦听属性。

计算属性的getter、setter

  1. computed 的属性可以被视为是 data 一样,可以 getter(读取)和 setter(设值),默认情况下 computed 预设只有 getter , 只能读取,不能改变设值。
// VUE.js 计算属性默认只有 getter, 因为是默认值所以我们也常常省略不写,如下代码:
computed: { fullName: function () { return this.firstName + ' ' + this.lastName } }// computed 里的代码完整的写法应该是:computed: { fullName: { get(){ return this.firstName + ' ' + this.lastName } } }

getter的触发时间

<template><div id="demo"><p> {{ fullName }} </p><input type="text" v-model="firstName"><input type="text" v-model="lastName"></div>
</template>var vm = new Vue({el: '#demo',data: {firstName: 'zhang',lastName: 'san'},computed: {fullName: function () {console.log('computed getter...')return this.firstName + ' ' + this.lastName}},updated () {console.log('updated')}
})

如果我们改变上边代码里的2个输入框的值firstName或者lastName,都会触发computed以及updated (),执行: console.log(‘computed getter…’)和console.log(‘updated’)

需要注意的是,不是说我们更改了getter里使用的变量,就会触发computed的更新,前提是computed里的值必须要在模板里使用才行。

如下代码,我们把template里的fullName 注释掉:

<template><div id="demo"><!-- <p> {{ fullName }} </p> --><input type="text" v-model="firstName"><input type="text" v-model="lastName"></div>
</template>var vm = new Vue({el: '#demo',data: {firstName: 'zhang',lastName: 'san'},computed: {fullName: function () {console.log('computed getter...')return this.firstName + ' ' + this.lastName}},updated () {console.log('updated')}
})

就算我们更改了firstName以及lastName都不会触发computed 中的 getter 中的console.log(‘computed getter…’),而只会触发console.log(‘updated’)

计算属性setter

<template><div id="demo"><p> {{ fullName }} </p><input type="text" v-model="fullName"><input type="text" v-model="firstName"><input type="text" v-model="lastName"></div>
</template>var vm = new Vue({el: '#demo',data: {firstName: 'zhang',lastName: 'san'},computed: {fullName: {//getter 方法get(){console.log('computed getter...')return this.firstName + ' ' + this.lastName},//setter 方法set(newValue){console.log('computed setter...')var names = newValue.split(' ')this.firstName = names[0]this.lastName = names[names.length - 1]return this.firstName + ' ' + this.lastName}}},updated () {console.log('updated')}
})

在template 中,我们可以看到,input 是直接绑 v-model=“fullName”,如果我们这里直接修改了fullName的值,那么就会触发setter,同时也会触发getter以及updated函数。其执行顺序是setter -> getter -> updated,如下:

console.log('computed setter...')
console.log('computed getter...')
console.log('updated')

这里需要注意的是,并不是触发了setter也就会触发getter,他们两个是相互独立的。我们这里修改了fullName会触发getter是因为setter函数里有改变firstName 和 lastName 值的代码。也就是说我们如果注释掉上边的setter中修改firstName 和lastName的代码后就不会执行getter,如下:

set(newValue){console.log('computed setter...')// var names = newValue.split(' ')//  this.firstName = names[0]//  this.lastName = names[names.length - 1]return this.firstName + ' ' + this.lastName}

会执行,且顺序如下

console.log('computed setter...')
console.log('updated')

Vue中computed 计算机属性、getter、setter相关推荐

  1. Vue中computed计算属性和data数据获取的问题

    获取到数据(对象.数组),截取一部分显示到页面中,用computed计算属性来实现截取数据然后直接输出到页面. <div class="detailBox"><h ...

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

    初学vue,阅读api后,发现Vue提供了多种逻辑处理的方法,单纯的方法methods,computed(计算属性)以及watch等,充分理解这三者的区别,才能写出更加健壮的Vue代码. 1.meth ...

  3. vue 中 computed 计算属性 的用法

    计算属性实质就是一个方法,只不过在使用的时候只把方法名称作为属性使用,不需要加(),而不是当做方法使用. 只有计算属性的方法内部所用到的任何data中的数据发生变化,就会立刻重新计算这个计算属性的值. ...

  4. vue中computed(计算属性)和watch在实现父子组件props同步时的实际区分

    vue中computed和watch的对比是一个很有意思的话题. 看过官网教程以后,我们往往更倾向多使用computed.computed优点很多,却在某些时候不太适用. 今天我们就稍微讨论一下,当我 ...

  5. vue方法调用失败后多次调用_浅析Vue中 computed / watch / methods的区别

    思考:请说下Vue中computed 和 watch 的区别( 面试题 ) 构造选项 computed / watch / methods computed ● computed 起初构想 在Vue的 ...

  6. Vue中computed分析

    Vue中computed分析 在Vue中computed是计算属性,其会根据所依赖的数据动态显示新的计算结果,虽然使用{{}}模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的,在模板中放入太 ...

  7. 面试题!vue中的计算属性、方法、侦听属性

    1.计算属性 详细的内容可跳转至vue 计算属性 可以使用计算属性来代替在表达式中进行的复杂运算,以便于能够更方便的维护与复用逻辑. 计算属性是在选项对象中使用 computed 字段来定义. 特点: ...

  8. vue中computed的详细讲解

    vue中computed的详细讲解 1.定义 2.用法 3.computed的响应式依赖(缓存) 4.应用场景 1.定义 computed是vue的计算属性,是根据依赖关系进行缓存的计算,只有在它的相 ...

  9. Vue中computed原理

    1.computed大致流程 computed是vue中的计算属性,在依赖的值发生变化的时候进行重新计算,否则使用缓存. 而在面试中常被问及computed原理,这篇文章主要作为我学习computed ...

最新文章

  1. spring boot构建基础版web项目(一)springboot、thymeleaf控制层基础构
  2. Linux 操作系统原理 — 内存 — mmap 进程虚拟内存映射
  3. java和python哪个好就业2020-JAVA和Python哪个好就业?
  4. CSAPP:第十一章 网络编程
  5. stm32F1的 PA13/PA14/PA15/PB3/PB4 作为普通引脚使用
  6. mac android通知中心,有什么软件可以把安卓通知栏变成苹果通知栏
  7. Go 语言接口详解(一)
  8. Vmware虚拟机全屏
  9. 26、python密度聚类方法(DBSCAN密度聚类)
  10. Windows去快捷方式角标
  11. 黑马培训学编程python
  12. 悔不当初:没人能随随便便成功
  13. 初级SHELL脚本(如何书写一个CentOS7的更改单网卡IP的shell脚本)
  14. 医院机房建设A类机房建设标准和B类、C类机房建设标准有什么差别
  15. 杜比的发展历史是什么?
  16. iconfont 转换为图标字体。
  17. oracle编码转换utf16,oracle编码转换:AL32UTF8-ZHS16GBK
  18. LaTex 把上下标符号放在正上和正下方公式
  19. Android利用canvas画各种图形(点、直线、弧、圆、椭圆、文字、矩形、多边形、曲线、圆角矩形)
  20. 将统一标识的SCV文件批量合成excel文件

热门文章

  1. AT SELECTION-SCREEN
  2. 路径标记语法 in Windows Presentation Foundation(WPF)
  3. 太原理工大学ICPC队介绍(2020版)
  4. HDU2077 汉诺塔IV【递推+打表】
  5. CCF201903-1 小中大(100分)【序列处理】
  6. 《程序设计技术》第三章例程
  7. JSK-27321 统计单词数【字符串】
  8. 51Nod-2149 字符串出现位置【水题】
  9. UVA11526 H(n)【数学】
  10. KMP算法(C++版)