一.插值语法实现姓名案例
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8"/>
<title>姓名案例 插值语法实现</title>
<script type="text/javascript" src="../js/vue.js">
</script>
</head>
<body>
<!-- 容器 -->
<div id="root">
姓:<input type="text" v-model="firstName"><br/>
名:<input type="text" v-model="lastName"><br/>
姓名:<span>{{firstName}}-{{lastName}}</span>
</div>
<script type="text/javascript" >
Vue.config.productionTip = false
new Vue({
el:"#root",
data:{
firstName:'张',
lastName:"三"
}
})
</script>
</body>
</html>
二.methods方法实现姓名案例
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8"/>
<title>姓名案例 插值语法实现</title>
<script type="text/javascript" src="../js/vue.js">
</script>
</head>
<body>
<!-- 容器 -->
<div id="root">
姓:<input type="text" v-model="firstName"><br/>
名:<input type="text" v-model="lastName"><br/>
姓名:<span>{{fullName()}}</span>
</div>
<script type="text/javascript" >
Vue.config.productionTip = false
new Vue({
el:"#root",
data:{
firstName:'张',
lastName:"三"
},
methods:{
fullName(){
//console.log("@",this)
return this.firstName+"-"+this.lastName;
}
}
})
</script>
</body>
</html>
三.计算属性
对于Vue来说,data中的配置对象(:{})为属性,冒号前为属性名,后为属性值
1.定义:要用的属性不存在,要通过已有属性计算得来
2.原理:底层借助了object.defineproperty方法提供的getter和setter
3.getter函数什么时候执行
(1)初次读取时会执行一次
(2)当依赖的数据发生改变时会被再次调用
4.优势:与=methods实现相比,内部会有缓存机制(复用),效率更高,调试方便
5.备注
(1)计算属性最终会出现在vm上,直接读取使用即可
(2)如果计算属性要被修改,那必须写set函数去相应修改,且set中要引起计算时依赖的数据发生改变
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8"/>
<title>姓名案例 插值语法实现</title>
<script type="text/javascript" src="../js/vue.js">
</script>
</head>
<body>
<!-- 容器 -->
<div id="root">
姓:<input type="text" v-model="firstName"><br/>
名:<input type="text" v-model="lastName"><br/>
姓名:<span>{{fullName}}</span><br/>
姓名:<span>{{fullName}}</span><br/>
姓名:<span>{{fullName}}</span><br/>
姓名:<span>{{fullName}}</span><br/>
</div>
<script type="text/javascript" >
Vue.config.productionTip = false
const vm = new Vue({
el:"#root",
data:{
firstName:'张',
lastName:"三"
},
computed:{
fullName:{
//get作用:当有人读取fullName时,get会被调用,且返回值就作为fullNAme的值
//get什么时候用。1初次读取fullname2.所依赖数据发生变化时
get(){
console.log('get调用')
console.log(this)
//可以看到this就是vm
return this.firstName + "-" + this.lastName
},
//set什么时候被调用?fullName被修改时
set(value){
const arr = value.split('-')
this.firstName = arr[0]
this.lastName = arr[1]
}
}
}
})
</script>
</body>
</html>
计算属性,自动拿到get返回值放到vm 身上(data中是属性放到vm身上,methods中是方法放到vm身上)
利用set,fullname被修改时,修改去该data中的firstname和lastname,计算属性fullname才会在页面被改
三.计算属性简写
计算属性只有get,没有set可简写
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8"/>
<title>姓名案例 插值语法实现</title>
<script type="text/javascript" src="../js/vue.js">
</script>
</head>
<body>
<!-- 容器 -->
<div id="root">
姓:<input type="text" v-model="firstName"><br/>
名:<input type="text" v-model="lastName"><br/>
姓名:<span>{{fullName}}</span><br/>
姓名:<span>{{fullName}}</span><br/>
姓名:<span>{{fullName}}</span><br/>
姓名:<span>{{fullName}}</span><br/>
</div>
<script type="text/javascript" >
Vue.config.productionTip = false
const vm = new Vue({
el:"#root",
data:{
firstName:'张',
lastName:"三"
},
computed:{
/*fullName:{
get(){
console.log('get调用')
console.log(this)
return this.firstName + "-" + this.lastName
},
set(value){
const arr = value.split('-')
this.firstName = arr[0]
this.lastName = arr[1]
}
}*/
//简写funName:function()=>fullName()
fullName(){
console.log('get调用')
console.log(this)
return this.firstName + "-" + this.lastName
}
}
})
</script>
</body>
</html>
更多情况,计算属性只是用来展示,不改。
简写,不用写配置对象,写为函数。再省略:function
喵一下是方法还是计算属性,
本文通过三个示例详细介绍了在Vue.js中如何实现姓名的显示:1)使用插值语法;2)通过methods方法;3)利用计算属性,并探讨了计算属性的缓存机制和setter的使用。示例代码清晰展示了数据绑定和响应式更新的过程,同时解释了计算属性在性能和调试方面的优势。
1388

被折叠的 条评论
为什么被折叠?



