初识Vue——计算属性和观察者
一、计算属性
在模板内使用
1、基础例子
<template>
<div class="main">
<div id="reverse_str">
<p>原始字符串:{{ msg }}</p>
<p>倒置字符串:{{ reversedmsg }}</p>
</div>
</div>
</template> <script>
export default {
name: 'test',
data () {
return {
msg: '梦里梦到醒不来的梦',
}
},
computed: {
//计算属性的getter
reversedmsg: function () {
return this.msg.split('').reverse().join('')
}
}
}
</script> <style>
#reverse_str{
color: powderblue;
}
</style>

解释说明:这里我们声明了一个计算属性reversemsg,我们提供的函数将用作属性的getter函数
2、计算属性缓存vs方法
以上还可以通过在表达式中调用方法来达到同样的效果:
<template>
<div class="main">
<div id="method">
<p>原始字符串:{{ msg1 }}</p>
<p>倒置字符串:{{ reversedmsg1() }}</p>
</div>
</div>
</template> <script>
export default {
name: 'test',
data () {
return {
msg1: '浮现你被软禁的红'
}
},
methods: {
reversedmsg1 () {
return this.msg.split('').reverse().join('')
}
}
}
</script> <style>
#method{
color: darksalmon;
}
</style>

这两种方式的结果是一模一样的;不同的是,计算属性是基于他们的依赖进行缓存的;计算属性只有在他的相关依赖发生改变时,才会重新求值;这就意味着只要msg没有发生改变,多次访问reversemsg计算属性会立即返回之前计算的结果,而不必再次执行函数;
这也意味着下面的计算属性将不再更新,因为Date.now()不是响应式依赖,
computed: {
// 计算属性的getter
now_time: function () {
return Date.now()
}
},
3、计算属性VS侦听属性
侦听属性:观察和相应Vue实例上的数据变动;watch回调
<template>
<div class="main">
<div id="sang">
<div class="watch_it">
<input v-model="first" />
<input v-model="last" />
<p>{{ fullname }}</p>
</div>
</div>
</div>
</template> <script>
export default {
name: 'test',
data () {
return {
sangname: '我如果爱你——',
author: '绝不学痴情的鸟儿,为绿荫重复单调的歌曲',
}
},
watch: {
first: function (val) {
this.fullname = val + ' ' + this.last
},
last: function (val) {
this.fullname = this.first + ' ' + val
}
}
}
</script> <style>
.watch_it input{
list-style: none;border: 1px seagreen solid;width: 200px;height:30px;color: gray;padding:0 10px;outline: none;
}
</style>

上面的代码是命令式的,且重复代码较多,下面来写一下计算属性的版本:
<template>
<div class="main">
<div id="sang">
<p>{{ sang }}</p>
</div>
</div>
</template> <script>
export default {
name: 'test',
data () {
return {
sangname: '我如果爱你——',
author: '绝不学痴情的鸟儿,为绿荫重复单调的歌曲',
},
computed: {
// 计算属性的getter
sang: function () {
return this.sangname + ' ' + this.author
}
}
}
</script> <style>
#sang{
color: cadetblue;
}
</style>

4、计算属性的setter
计算属性只有默认的getter,不过在必要的时候你可以自定义一个setter
<template>
<div class="main">
<div id="sang">
<p>{{ sang }}</p>
</div>
</div>
</template> <script>
export default {
name: 'test',
data () {
return {
sangname: '我如果爱你——',
author: '绝不学痴情的鸟儿,为绿荫重复单调的歌曲',
}
},
computed: {
sang: {
//getter
get: function () {
return this.sangname + ' ' + this.author
},
set: function (newval) {
var sentence = newval.split(' ')
this.sangname = sentence[0]
this.author = sentence[sentence.length - 1]
}
}
}
}
</script> <style>
#sang{
color: cadetblue;
}
</style>
二、侦听器
虽然计算机属性可以适用于大多数情况,但有时也需要一个自定义的侦听器;
暂无
初识Vue——计算属性和观察者的更多相关文章
- vue计算属性和观察者
1. 计算属性 模板内的表达式非常便利,但在模板中放入太多的逻辑会让模板过重且难以维护,所有就有了计算属性 例子: //html代码 <div id="example"> ...
- 前端MVC Vue2学习总结(三)——模板语法、过滤器、计算属性、观察者、Class 与 Style 绑定
Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据.所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解 ...
- 七、vue计算属性
细节流程图 初始化 计算属性的初始化是发生在 Vue 实例初始化阶段的 initState 函数中,执行了 if (opts.computed) initComputed(vm, opts.compu ...
- Vue计算属性
github地址:https://github.com/lily1010/vue_learn/tree/master/lesson06 一 计算属性定位 当一些数据需要根据其它数据变化时,这时候就需要 ...
- 在做vue计算属性,v-for处理数组时遇到的一个bug
bug: You may have an infinite update loop in a component render function 无限循环 需要处理的数组(在 ** ssq **里): ...
- vue教程2-03 vue计算属性的使用 computed
vue教程2-03 vue计算属性的使用 computed computed:{ b:function(){ //默认调用get return 值 } } ---------------------- ...
- vue 计算属性 实例选项 生命周期
vue 计算属性: computed:{} 写在new vue()的属性,只要参与运算,数据不发生变化时,次计算只会执行一次,结果缓存,之后的计算会直接从缓存里去结果.如果其中的值发生变化(不管几个) ...
- Vue计算属性缓存(computed) vs 方法
Vue计算属性缓存(computed) vs 方法 实例 <div id="example"> <p>Original message: "{{ ...
- vue 计算属性实现过滤关键词
效果 html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <m ...
随机推荐
- List源码学习之LinkedList
LinkedList 内部数据接口为一个链表,存储数据可为空可重复. 1.包含主要参数: //集合长度transient int size = 0; /** * 头结点 */ transient No ...
- jdbc参数
JDBC连接池参数: jdbc.initialSize=0 //初始化连接 jdbc.maxActive=30 //连接池的最大数据库连接数,设为0表示无限制 j ...
- MyEclipse中导出javadoc文档
1.选中要生成文档的类或者项目→File→Export→Java→Javadoc. 2.在Javadoc command中选择JDK下对应的javadoc.exe:Select types for w ...
- maven的聚合和继承
Maven的聚合特性能够把项目的各个模块聚合在一起构建: 而Maven的继承特性则能帮组抽取各模块相同的依赖和插件等配置,在简化POM的同时,还能促进各个模块配置的一致性. 聚合:新建一个项目demo ...
- Matlab产生TestBeach所需要的波形数据
在用vivado仿真的时候,很多情况下需要自己产生波形来代替AD采样波形.以前的做法都是用DDS内部产生所需要的波形来模仿外部输入,后来发现这种做法不仅麻烦,而且不易修改,对仿真很不友好.于是改用ma ...
- IE各个版本的差异性
1.IE6a.不支持png半透明图片,只能用filter实现b.不支持css的max-width.max-height.min-width.min-height其他不用说,一团糟,不过项目中还是得去兼 ...
- Windows下Nginx实现负载均衡
Apache,Nginx Apache和Nginx都属于属于 静态页面服务器,都有插件支持动态编程语言处理,但Nginx的IO模比Apache更适合跑代理.所以一般都作为前端缓冲代理(Nginx的反向 ...
- MP4大文件虚拟HLS分片技术,避免服务器大量文件碎片
MP4大文件虚拟HLS分片技术,避免点播服务器的文件碎片 本文主要介绍了通过虚拟分片技术,把MP4文件,映射为HLS协议中的一个个小的TS分片文件,实现了在不实际切分MP4文件的情况下,通过HLS协议 ...
- 我的第一个Android开源库——CirclePointMove中文文档(可随Viewpager移动的指示器)
Github网址:https://github.com/Stars-One/CirclePointMove 这个开源库一个封装好的Viewpager指示器,之前在学习的时候,想要实现一个小圆点跟随Vi ...
- 应用ntpdate小工具同步时间
应用ntpdate小工具同步时间: ntpdate pool.ntp.org 中国的时间服务器有: ntpdate .cn.pool.ntp.org ntpdate .asia.pool.ntp.or ...