Vue computed 计算属性代码实例

作者:北宫乾宇 时间:2024-05-09 15:14:39 

什么是计算属性???

1、在computed中,可以定义一些属性,这些属性叫做【计算属性】

2、计算属性的本质是一个方法,不过一般是将他们的名称直接当做属性使用,不会当方法调用


<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <script src="../lib/vue-2.4.0.js"></script>
</head>
<body>
<div id="app">
 <input type="text" v-model="firstname">+
 <input type="text" v-model="lastname">=
 <input type="text" v-model="fullname">
</div>
<script>
 var vm = new Vue({
   el: '#app',
   data: {
     firstname: '',
     lastname: ''
   },
   methods: {},
   computed:{
     // 在computed中,可以定义一些属性,这些属性叫做【计算属性】
     // 计算属性的本质是一个方法,不过一般是将他们的名称直接当做属性使用,不会当方法调用
     'fullname':function () {
       return this.firstname + '-' + this.lastname;
     }
    }
 })
</script>
</body>
</html>

重点注意

1、计算属性,在调用的时候,一定不要加()去调用,直接将它当做普通属性使用

2 、计算属性的function中引用的data中的数据发生了变化,就会立即重新计算这个计算属性的值

3、 计算属性的求值结果,会被缓存起来,方便下次直接使用;如果计算属性方法中,所有来的任何数据没有发生改变,则不会重新计算

内容扩展

vue之computed(计算属性)的使用方法

在vue中,一些简易的计算可以直接在模板中计算,如:{{ number + 1 }};但是在模板中如果有太多复杂的计算难以维护;所以对于任何复杂的逻辑,你都应该使用计算属性的原因;

1.经过处理返回的数据值,只要源数据没有发生改变,computed函数里面对相应的数据就不会反生改变,相当于缓存在本地;发生改变的时候,computed对应数据的函数也会发生改变;

2:computed属性和methods属性

你可能已经注意到我们可以通过调用method来达到同样的效果:我们可以将同一个函数定义为一个method而不是一个计算属性,对于最终的结果,两种方式确实是相同的;

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

3:computed中的属性;

计算属性默认只有getter不过在需要时也可以提供一个setter;


var vm=new Vue({
el:"#demo",
data:{
firstName:"foo",
lastName:"Bar",
fullName:"foo Bar"
},
computed:{
fullName:function(){
  get:function(){
    return this.firstName+" "+this.lastName;
  },
  setter:function(){
    var names=newValue.split('');
    this.firstName=names[0];
    this.lastName=names[names.length-1]
  }
}
}
});

来源:https://www.cnblogs.com/myfaith-feng/p/12748800.html

标签:Vue,computed,计算属性
0
投稿

猜你喜欢

  • 基于python使用Pillow做动态图在图中生成二维码以及图像处理

    2022-12-29 16:33:03
  • Vue3中watch的使用详解

    2024-05-09 15:20:19
  • Vue.js 2.5新特性介绍(推荐)

    2024-05-13 09:09:00
  • python实现电子词典

    2023-05-14 00:29:01
  • python自动化测试selenium操作下拉列表实现

    2023-09-06 00:26:50
  • python list.sort()根据多个关键字排序的方法实现

    2021-05-22 03:16:09
  • 基于Tensorflow高阶读写教程

    2022-10-05 02:37:27
  • python智联招聘爬虫并导入到excel代码实例

    2023-09-28 14:18:00
  • python学习之面向对象【入门初级篇】

    2023-11-19 19:59:44
  • Scrapy 之中间件(Middleware)的具体使用

    2023-01-10 19:50:22
  • mysql中limit查询踩坑实战记录

    2024-01-16 13:38:45
  • SQL Server中选出指定范围行的SQL语句代码

    2024-01-28 08:39:14
  • PHP获取指定日期是星期几的实现方法

    2024-05-09 14:47:21
  • mysql5在rhel5下乱码问题及解决方法

    2010-12-03 16:26:00
  • Python 解决空列表.append() 输出为None的问题

    2023-07-24 14:07:57
  • 如何处理好网页色彩搭配

    2007-08-10 13:22:00
  • Python连接mysql方法及常用参数

    2024-01-15 00:33:54
  • MySQL数据库手册DATABASE操作与编码(小白入门篇)

    2024-01-24 16:20:54
  • Python基于百度API识别并提取图片中文字

    2023-02-06 13:51:25
  • Python unittest 自动识别并执行测试用例方式

    2023-08-14 07:09:39
  • asp之家 网络编程 m.aspxhome.com