简介

计算属性关键词: computed。

计算属性在处理一些复杂逻辑时是很有用的。

实例1

可以看下以下反转字符串的例子:

<div id="app">
{{ message.split('').reverse().join(' | ')}}
</div> <script>
new Vue({
el: '#app',
data: {
message: '上海自来水来自海上'
}
})
</script>

上面例子中模板变的很复杂起来,也不容易看懂理解。

实例2

接下来我们看看使用了计算属性的实例:

<div id="app">
{{message}}
<br>
{{reverseMessage}}
</div> <script>
new Vue({
el: '#app',
data: {
message: '上海自来水来自海上'
},
computed:{
// 计算属性的 getter
reverseMessage:function(){
// `this` 指向 vm 实例
return this.message.split('').reverse().join(' | ')
}
}
})
</script>

上面实例中声明了一个计算属性 reversedMessage 。

提供的函数将用作属性 vm.reversedMessage 的 getter 。

vm.reversedMessage 依赖于 vm.message,在 vm.message 发生改变时,vm.reversedMessage 也会更新。

vue.js里computed 和 methods的区别

我们可以使用 methods 来替代 computed,效果上两个都是一样的,但是 computed 是基于它的依赖缓存,只有相关依赖发生改变时才会重新取值。而使用 methods ,在重新渲染的时候,函数总会重新调用执行。

<div id="app">
{{message}}
<br>
{{reverseMessage1()}}
<br> <!--注意方法是要加上()的,而属性不需要-->
{{reverseMessage2}}
</div> <script>
new Vue({
el: '#app',
data: {
message: '上海自来水来自海上'
},
methods:{
reverseMessage1:function(){
// `this` 指向 vm 实例
return this.message.split('').reverse().join(' # ')
}
},
computed:{
reverseMessage2:function(){
// `this` 指向 vm 实例
return this.message.split('').reverse().join(' | ')
}
}
})
</script>

可以说使用 computed 性能会更好,但是如果你不希望缓存,你可以使用 methods 属性。

computed setter

computed 属性默认只有 getter ,不过在需要时你也可以提供一个 setter :

<div id="app">
<p>{{ userinfo }}</p>
</div> <script>
var vm = new Vue({
el: '#app',
data: {
username: '刘凯',
department: '财务部'
},
computed: {
userinfo: {
// getter
get: function () {
return this.username + '#' + this.department
},
// setter
set: function (newinfo) {
var infos = newinfo.split('#')
this.username = infos[0]
this.department = infos[infos.length - 1]
}
}
}
})
// 调用 setter, vm.username 和 vm.department 也会被对应更新
vm.userinfo = '张晓晓#销售部';
document.write('username: ' + vm.username);
document.write('<br>');
document.write('department: ' + vm.department);
</script>

vm.userinfo = '张晓晓#销售部'这一行代码是关键,分别注释掉和打开注释运行这段代码,分别会出现一下两种结果

刘凯#财务部

username: 刘凯
department: 财务部
张晓晓#销售部

username: 张晓晓
department: 销售部

Vue(七):computed计算属性的更多相关文章

  1. Vue之computed计算属性

    demo.html <!DOCTYPE html> <html lang="en" xmlns:v-bind="http://www.w3.org/19 ...

  2. Vue的computed计算属性是如何实现的

    一个开始 有如下代码,full是一个计算属性,开始,他的值是'hello world',1s后,msg变成了‘I like’, full的值同步变成了'I like world';其原理解析来看一下. ...

  3. Vue中computed计算属性

    话不多说,使用方法直接上代码//在模板中调用computedTest这个函数,切记不要在函数后添加()<template> <div class="home"&g ...

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

    实现效果:字符串的动态拼接 methods方法 html: <div id="app"> <!-- 监听到文本框数据的改变 --> <input ty ...

  5. vue的computed计算属性

    computed可定义一些函数,这些函数叫做[计算属性] 只要data里面的数据发生变化computed会同步改变 引用[计算属性]时不要加  () ,应当普通属性使用 例:console.log(t ...

  6. Vue的computed(计算属性)使用实例之TodoList

    最近倒腾了一会vue,有点迷惑其中methods与computed这两个属性的区别,所以试着写了TodoList这个demo,(好土掩面逃~); 1. methods methods类似react中组 ...

  7. vue中computed计算属性与methods对象中的this指针

    this 指针问题 methods与computed中的this指针 应该指向的是它们自己,可是为什么this指针却可以访问data对象中的成员呢? 因为new Vue对象实例化后data中的成员和c ...

  8. 小白学习vue第三天,从入门到精通(computed计算属性)

    computed计算属性 <body> <div id="app"> <div>{{myName}}</div> </div& ...

  9. 深入理解 Vue Computed 计算属性

    Computed 计算属性是 Vue 中常用的一个功能,我们今天来说一下他的执行过长 拿官网简单的例子来看一下: <div id="example"> <p> ...

随机推荐

  1. Statement、PreparedStatemnt、CallableStatement

    第一.Statement(Statement代表一个特定的容器,来对一个特定的数据库执行语句) * 执行查询的方法 Statement=Connection.createStatement();//创 ...

  2. Atlas:ERROR 1105 (HY000): #07000Proxy Warning - IP Forbidden

    1:遇到一个奇怪的问题 Atlas的管理接口正常 添加一个client之后save config mysql -uroot -p -P1234 -h127.0.0.1 报错了:ERROR 1105 ( ...

  3. 如何捕获 System.loadLibrary 产生的异常?(转)

    如何捕获 System.loadLibrary 产生的异常? 当使用以下代码时,会发现异常处理的代码根本不会被执行: try{ System.loadLibrary("SimpleAuthe ...

  4. Java通过在主循环中判断Boolean来停止线程

    Java代码: package Threads; /** * Created by Frank */ public class StopBoolean extends Thread { // 确保变化 ...

  5. python模块之linecache

    # -*- coding: utf-8 -*- #python 27 #xiaodeng #python模块之linecache import linecache ''' >>> h ...

  6. DLib压缩解压程序示例

    /* 这是一个示例程序,使用了Dlib库的compress_stream和cmd_line_parser组件. 这个示例实现了一个简单实用的命令行压缩程序. 当使用-h选项时候,程序输出如下: 使用: ...

  7. Docker配置私有仓库

    One of the latest beta features of the open source Docker v2 Registry is the ability to act as a reg ...

  8. 1万字!彻底看懂微信小程序

    Q:为什么说小程序如炮友? A:小程序刚发布不久就流行一个段子:APP如原配,一年不用几次:服务号如情人,一个月固定几次:订阅号如酒店小卡片,天天可以卖广告:小程序像炮友,用完就走. 资本如嫖客,各个 ...

  9. Dubbo创建提供者&消费者工程

    1. 前言 Dubbo采用全Spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Spring加载Dubbo的配置即可,Dubbo基于Spring的Schema扩展进行加载.如果不想使 ...

  10. <转>字节码指令

    本文转自:http://www.cnblogs.com/nazhizq/p/6525263.html 在llimits.h文件中定义了指令的类型.其实就是32个字节. typedef lu_int32 ...