Vue computed 计算属性代码实例


Posted in Javascript onApril 22, 2020

什么是计算属性???

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]
   }
 }
}
});

到此这篇关于Vue computed 计算属性代码实例的文章就介绍到这了,更多相关Vue之computed 计算属性内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
JS获取dom 对象 ajax操作 读写cookie函数
Nov 18 Javascript
关于jQuery的inArray 方法介绍
Oct 08 Javascript
JavaScript闭包 懂不懂由你反正我是懂了
Oct 21 Javascript
javascript 中that的含义示例介绍
May 14 Javascript
JS创建类和对象的两种不同方式
Aug 08 Javascript
node.js中的console.error方法使用说明
Dec 10 Javascript
JavaScript实现256色转灰度图
Feb 22 Javascript
d3.js实现立体柱图的方法详解
Apr 28 Javascript
javascript  数组排序与对象排序的实例
Jul 17 Javascript
AngularJS实现与后台服务器进行交互的示例讲解
Aug 13 Javascript
详解vue中在父组件点击按钮触发子组件的事件
Nov 13 Javascript
Canvas跟随鼠标炫彩小球的实现
Apr 11 Javascript
js 解析 JSON 数据简单示例
Apr 21 #Javascript
react 原生实现头像滚动播放的示例
Apr 21 #Javascript
解决angular 使用原生拖拽页面卡顿及表单控件输入延迟问题
Apr 21 #Javascript
javascript设计模式 ? 策略模式原理与用法实例分析
Apr 21 #Javascript
javascript设计模式 ? 备忘录模式原理与用法实例分析
Apr 21 #Javascript
VUE+elementui组件在table-cell单元格中绘制微型echarts图
Apr 20 #Javascript
Vue的全局过滤器和私有过滤器的实现
Apr 20 #Javascript
You might like
WAMP环境中扩展oracle函数库(oci)
2015/06/26 PHP
php防止表单重复提交实例讲解
2019/02/11 PHP
将jQuery应用于login页面的问题及解决
2009/10/17 Javascript
jQuery 版元素拖拽原型代码
2011/04/25 Javascript
JavaScript常用全局属性与方法记录积累
2013/07/03 Javascript
Javascript模块化编程详解
2014/12/01 Javascript
js 获取元素在页面上的偏移量的方法汇总
2015/04/13 Javascript
JS实现自动变换的菜单效果代码
2015/09/09 Javascript
Bootstrap的Carousel配合dropload.js实现移动端滑动切换图片
2017/03/10 Javascript
详解Vue爬坑之vuex初识
2017/06/14 Javascript
javascript实现Java中的Map对象功能的实例详解
2017/08/21 Javascript
原生JS实现移动端web轮播图详解(结合Tween算法造轮子)
2017/09/10 Javascript
node.js利用mongoose获取mongodb数据的格式化问题详解
2017/10/06 Javascript
vue基础之data存储数据及v-for循环用法示例
2019/03/08 Javascript
js中let能否完全替代IIFE
2019/06/15 Javascript
Vue.js实现可编辑的表格
2019/12/11 Javascript
Python程序中的观察者模式结构编写示例
2016/05/27 Python
异步任务队列Celery在Django中的使用方法
2018/06/07 Python
Python并发之多进程的方法实例代码
2018/08/15 Python
使用selenium模拟登录解决滑块验证问题的实现
2019/05/10 Python
python中threading开启关闭线程操作
2020/05/02 Python
python编写一个会算账的脚本的示例代码
2020/06/02 Python
Pycharm及python安装详细教程(图解)
2020/07/31 Python
Python之字典对象的几种创建方法
2020/09/30 Python
Python列表的深复制和浅复制示例详解
2021/02/12 Python
考博自荐信
2013/10/25 职场文书
工商管理实习生自我鉴定范文
2013/12/18 职场文书
公司财务流程之主管工作流程
2014/03/03 职场文书
我为自己代言广告词
2014/03/18 职场文书
毕业晚会主持词
2014/03/24 职场文书
《英英学古诗》教学反思
2014/04/11 职场文书
合作协议书怎么写
2014/04/18 职场文书
承诺书范本
2015/01/21 职场文书
工会工作个人总结
2015/03/03 职场文书
暑期工社会实践报告
2015/07/13 职场文书
MySQL分库分表详情
2021/09/25 MySQL