<template>
<h1>{{fullName}}</h1>
</template>
computed:{
//完整的写法
fullName:{
get(){
retuen this.name
}
set(value){
this.name = value
}
}
//简写
fullName(){
return this.name
}//此时就想当于是getter
}
监听属性watch
watch:{
//当有除回调函数的其它配置项时只能完整的写
fullName:{
//还有很多配置属性
immediate:true,//初始化时让handler调用,默认false
deep:true,//开启深度监视,为了效率默认是不开的
handler(newValue,oldValue){}
}
//当只有回调函数时就可以简写成下面这样
fullName(newValue,oldValue){}
}
还可以通过下面这样,vm是vue的实例
vm.$watch('fullName',handler(){})
简写
vm.$watch('fullName',function(newValue,oldValue){})
watch中的深度监视
大部分情况下两者能实现功能都差不多,根据需求选择。
但是当根据变化要做异步处理时,此时只能使用监听属性,原因是计算属性必须返回一个值,当进行异步操作时此时就会有this指向问题。
原则:
1.被vue管理的函数,最好写成普通函数,这时this的指向才是组件实例对象或者vue实例
2.不被vue管理的函数最好写成箭头函数(定时器的回调,promise的回调,ajax的回调),写成监听函数此时this才能指向组件实例对象或者vue实例