// new 一个vue对象
const vm = new Vue({
// 挂载节点块 对应节点
el: '#demo',
// 起始数据块(起始参数) 对应 v-modul
data: {
firstName: 'A',
lastName: 'B',
// fullName1: 'A B'
fullName2: 'A B'
},
//
// //计算属性 逻辑块
computed: {
// 什么时候执行:初始化显示/相关的data属性数据发生改变
// 计算并返回当前属性的值
// 方法
fullName1(){//计算属性的一个方法,方法的返回值作为属性值
console.log('fullName1()');//打印一个函数方法
return this.firstName + ' ' + this.lastName ;//this是这个函数,值返回到fullName1 v-modle互相传递
},
//回调方法
fullName3: {//赋值fullName3 的对调函数
/*回调函数要满足3个条件:
1、你定义的;
2、你没有调用;
3、但最终它执行了
什么时候调用?
用来做什么? */
// 回调函数,当需要读取当前属性值时回调,根据相关的数据计算并返回当前属性的值
get(){return this.firstName + ' ' + this.lastName;},//返回拼合的结果,fullName3
// 回调函数,监视当前属性值的变化,当属性值发生改变时回调,更新相关的属性数据
set(value){// value就是fullName3的最新属性值 : 传递v-modle 的属性值,裁切后get返回
const names = value.split(' ');
this.firstName = names[0];
this.lastName = names[1];// 给name 赋值
}
}
},
// // // 监听块逻辑
// watch: { //监听firstName
// //data.firstName发生了变化
// firstName: function(value){
// console.log(this); //就是VM对象
// this.fullName2 = value + ' ' + this.lastName;
// },
// lastName: function(value){
// console.log(this); //就是VM对象
// this.fullName2 = this.firstName + ' ' + value;
// }
// }
});
// // vue外添加监听 lastName
vm.$watch('firstName', function(value){
// 更新fullName2
this.fullName2 = value + ' ' + this.lastName;
});
vm.$watch('lastName', function(value){
// 更新fullName2
this.fullName2 = this.firstName + ' ' + value;
});
vue计算属性与监视
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 一、模块 1、定义 1.动态的 html 页面2.包含了一些 JS 语法代码a. 双大括号表达式b. 指令(以 v...
- 一、vue实例属性gfhg 1.el获取vue绑定的元素的,可以对元素的style进行操作 2.data 获取vu...
- Vue 计算属性与监听器 在开发过程中,我们可能会遇到这样的需求:当你有两个或更多的数据,你并不希望把他们全部罗列...
- 在模板中表达式非常便利,但是它们实际上只用于简单的操作。模板是为了描述视图的结构。在模板中放入太多的逻辑会让模板过...