时间:2021-05-26
computed
computed:相当于method,返回function内return的值赋值在html的DOM上。但是多个{{}}使用了computed,computed内的function也只执行一次。仅当function内涉及到Vue实例绑定的data的值的改变,function才会从新执行,并修改DOM上的内容。
computed和method的对比
<div id="example"> {{ message.split('').reverse().join('') }}</div>这个是vue官网一直拿来作为例子的代码。在{{}}可以很方便的放入单个表达式,但是当一个HTML的DOM里面存在太多的表达式,程序会变得很笨重难于维护。
html
<div id="app9"> 9、method与computed的区别<br/> fullName<br/> {{fullName}}<br/> fullName2<br/> {{fullName}}<br/> fullNameMethod<br/> {{getFullName()}}<br/> fullNameMethod2<br/> {{getFullName()}}<br/></div>js
var app9 = new Vue({ el: '#app9', data: { firstName: 'Foo', lastName: 'Bar' }, methods:{ getFullName:function () { console.log("执行了methods") return this.firstName+" " +this.lastName; } }, computed: { fullName: function () { console.log("执行了computed") return this.firstName + ' ' + this.lastName } }})setTimeout('app9.firstName="Foo2"',3000);控制台输出的结果
执行了computed
执行了methods
执行了methods
执行了computed
执行了methods
执行了methods
由此可见使用computed,function只会执行一次。当Vue实例中绑定的data数据改变的时候,computed也相对应的只改变一次。
相同点:在以上代码中,两个p标签都会打印出同样被反转的Hello。
不同点:
使用了methods的:HTML中,每一个调用了Vue的methods的方法,都需要执行一遍reversedMessage()这个方法;
而使用computed计算属性的,只执行一遍将结果保存在缓存中。
computed和watch的对比
html
<div id="demo">{{ fullName }}</div>js
var vm = new Vue({ el: '#demo', data: { firstName: 'Foo', lastName: 'Bar', fullName: 'Foo Bar' }, watch: { firstName: function (val) { this.fullName = val + ' ' + this.lastName }, lastName: function (val) { this.fullName = this.firstName + ' ' + val } }})var vm = new Vue({ el: '#demo', data: { firstName: 'Foo', lastName: 'Bar' }, computed: { fullName: function () { return this.firstName + ' ' + this.lastName } }})以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了vue计算属性computed的使用方法。分享给大家供大家参考,具体如下:computed:{b:function(){//默认调用getretu
今天给大家分享下vue.js中的计算属性(computed)示例一computed的get属性html:{{fullName}}js:exportdefault
前言本文非vue教程,仅为学习vue过程中的个人理解与笔记,有说的不正确的地方欢迎指正讨论1、computed计算属性函数中不能使用vm变量在计算属性的函数中,
响应式侦听和计算有时我们需要依赖于其他状态的状态——在Vue中,这是用组件计算属性处理的,以直接创建计算值,我们可以使用computed方法:它接受getter
什么是计算属性???1、在computed中,可以定义一些属性,这些属性叫做【计算属性】2、计算属性的本质是一个方法,不过一般是将他们的名称直接当做属性使用,不