计算属性是自动监听依赖值的变化,从而动态返回内容,监听是一个过程,在监听的值变化时,可以触发一个回调,并做一些事情。特点:

  • 监测的是依赖值,依赖值不变的情况下其会直接读取缓存进行复用,变化的情况下才会重新计算
  • 数据可以进行逻辑处理,减少模板中计算逻辑。
  • 对计算属性中的数据进行监视

计算属性由两部分组成:get和set,分别用来获取计算属性和设置计算属性。默认只有get,如果需要set,要自己添加。另外set设置属性,并不是直接修改自身的值,而是修改它的依赖。

computed: {fullName: {// getterget () {return this.firstName + ' ' + this.lastName},// setterset (newValue) {//this.fullName = newValue 这种写法会报错var names = newValue.split(' ')this.firstName = names[0]//对它的依赖进行赋值this.lastName = names[names.length - 1]}}
}

现在再运行 vm.fullName = 'John Doe' 时,setter 会被调用,vm.firstName 和 vm.lastName 也会相应地被更新

计算属性必须写get,set的场景

计算属性默认只有 getter,不过在需要时你也可以提供一个 setter: 当你去设置计算属性时,也就是去修改计算属性时,需要写成get,set的方式

如果没有写会直接报错,比如

<template><div class="a"><button @click="add">点击{{closure}}</button></div>
</template><script>
export default {props: {},data() {return {a: 1}},computed: {closure() {return 'abc'}},methods: {add() {this.closure = 'defg'}}
}
</script>

正确写法

computed: {closure: {get() {console.log(123)return 'abc'},set(value) {// 那这个地方就只能拿值而不能修改closure的值了// this.closure = 'value'  会报错//做一些其他逻辑console.log(value)}}},methods: {add() {// 修改无效this.closure = 'defg'}}

get set应用场景1

用v-model来实现双向绑定(推荐用watch)

visible: {get() {return this.value},set(val) {}}

get set应用场景2

双向绑定的计算属性+vuex

<input v-model="message">// ...
computed: {message: {get () {return this.$store.state.obj.message},set (value) {this.$store.commit('updateMessage', value)}}
}

可缓存性

<p>Reversed message: "{{ reversedMessage() }}"</p>
// 在组件中
methods: {reversedMessage: function () {return this.message.split('').reverse().join('')}
}

计算属性是基于它们的响应式依赖进行缓存的。只在相关响应式依赖发生改变时它们才会重新求值。这就意味着只要 message 还没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。

这也同样意味着下面的计算属性将不再更新,因为 Date.now() 不是响应式依赖:

computed: {now: function () {return Date.now()}
}

计算属性可以通过闭包来实现传参

:data="closure(item, itemName, blablaParams)"
computed: {closure () {return  (a, b, c)=> {/** do something */return data}}
}

如果用闭包来实现传参,那么计算属性不具有可缓存性。

与watch进行对比

  • watch:监测的是属性值, 只要属性值发生变化,其都会触发执行回调函数来执行一系列操作。
  • computed:监测的是依赖值,依赖值不变的情况下其会直接读取缓存进行复用,变化的情况下才会重新计算。
  • 计算属性不能执行异步任务,计算属性必须同步执行,watch可执行异步任务,遇到异步任务,就交给侦听属性
  • watch也可以检测computed属性

总结

计算属性适合用在模板渲染中,某个值是依赖了其它的响应式对象甚至是计算属性计算而来;而侦听属性适用于观测某个值的变化去完成一段复杂的业务逻辑。

  • computed能做的,watch都能做,反之则不行
  • 能用computed的尽量用computed

vue 计算属性和data_Vue计算属性原理和使用场景相关推荐

  1. vue 计算属性和data_Vue:计算属性

    一.为什么要使用计算属性 1.什么是计算属性 计算属性:可以理解为能够在里面写一些计算逻辑的属性.具有如下的作用: 减少模板中的计算逻辑. 数据缓存.当我们的数据没有变化的时候,不会再次执行计算的过程 ...

  2. vue 计算属性和data_Vue 计算属性问题?

    1.代码复用 computed: { position() { return ((!this.right || this.right < 0) ? 0 : (this.right > 75 ...

  3. vue 计算属性和data_vue之watch和计算属性computed

    区别一:watch监听的是一个变量(或者一个常量)的变化,这个变量可能是一个单一的变化也可能是一个数组.computed可以监听很多个变量,但是这个变量一定是vue实例里面的. Vue 测试实例 - ...

  4. vue 计算属性和data_Vue.js教程(五)--Vue的计算属性

    模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.例如: {{ message.split('').reverse().join('') }} ...

  5. vue使用,及指令介绍,计算属性/过滤器

    目录 Vue是什么 vue的单页面原理 Vue的使用 指令介绍: v-if和 v-show的区别 v-on 事件绑定: v-bind 绑定属性 处理数组绑定 v-model双向数据绑定 created ...

  6. Vue计算属性和监听属性

    一.计算属性 计算属性关键词: computed.计算属性在处理一些复杂逻辑时是很有用的. 可以看下以下反转字符串的例子: <div id="app">{{ messa ...

  7. Vue 模板语法 插值操作 绑定属性 计算属性 事件监听 条件判断 循环遍历 阶段案例

    1 插值操作 1.1 Mustache语法 也就是双大括号 {{ }} <div id="app"> <!-- mustche语法中,不仅可以直接写变量,也可以写 ...

  8. vue源码-对于「计算属性」的理解

    vue源码-对于「计算属性」的理解 这是我最近学习vue源码的一个个人总结和理解,所以可能并不适合每一位读者 本文的整体脉络如下,首先尽可能去掉细节,对计算属性源码的大致实现有一个了解,然后举一例子, ...

  9. oclick vue 传参 函数_详解Vue计算属性和侦听属性

    关注[搜狐技术产品]公众号,第一时间获取技术干货 作者介绍: 本期特邀作者:浪里行舟 Github博客2600 star作者,专注于前端领域.个人公众号:「前端工匠」,致力于打造适合初中级工程师能够快 ...

最新文章

  1. 斯坦福CS224n、CMU NLP公开课 播放地址
  2. layui fixbar 返回顶部_FANUC 数控系统机床返回参考点功能的应用研究
  3. 5.2 大间距分类器-机器学习笔记-斯坦福吴恩达教授
  4. MySQL 8.0 技术详解
  5. 在ubuntu20.10上搭建SVN Server
  6. C语言 | 编程实现5
  7. 表示和描述-边界追踪
  8. 工作335:uni-增加表单验证
  9. android 字典转json,在Swift中将字典转换为JSON
  10. C++11 chrono库
  11. JSP实用教程(3)——JSP内置对象
  12. 大一计算机文化基础复习资料,转 大一计算机文化基础试题及答案
  13. Java 验证码图片不加载处理办法
  14. [转]海南楼市泡沫拯救中国经济~ 恍然大悟呀~
  15. 【类型初始值设定项引发异常】问题解决
  16. 十一、SpringCloud实用篇_Gateway服务网关
  17. vue 路由懒加载 报错 Loading chunk * failed 组件加载不出来
  18. IDEA中的单元测试模块(Junit)不能自动导包
  19. 大数据技术之Kylin
  20. getPrepayId php,获取到 prepay_id 后将参数再次签名传输给 APP 发起支付

热门文章

  1. 百度2020Q3财报:“十四五”规划注入新动能,百度智能云驶入快车道
  2. LOL快要凉?腾讯电竞应如何破除游戏生命周期诅咒
  3. php 安装pdo odbc,关于PHP安装扩展pdo_odbc
  4. java代码如何避免死锁,Java可重入锁如何避免死锁
  5. php中文网地址多少,计算机网络中有几种地址格式
  6. python函数定义与使用
  7. python 面向对象教程:访问限制
  8. Python中maketrans和translate方法
  9. Python的locals()函数
  10. python中yield函数的作用?