计算属性

简介: 计算属性
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>计算属性</title>
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id="root">
        姓:<input type="text" v-model="firstName"><br><br>
        名:<input type="text" v-model="lastName"><br><br>
        姓名:<span>{{fullName}}</span>
    </div>
    <script>
        Vue.config.productionTip = false 
        new Vue({
            el:'#root', 
            data:{ 
                firstName:'张',
                lastName:'三'
            },
            computed:{
                fullName:{
                    get(){
                        return this.firstName + '-' + this.lastName
                    },
                    set(value){
            const arr = value.split('-')
            this.firstName = arr[0]
            this.lastName = arr[1]
                    }
                }
            }
        })
    </script>
</body>
</html>

效果:

总结:


计算属性:

定义:要用的属性不存在,需要通过已有属性计算得来。

原理:底层借助了Objcet.defineproperty()方法提供的getter和setter。

get函数什么时候执行?

初次读取时会执行一次

当依赖的数据发生改变时会被再次调用

优势:与methods实现相比,内部有缓存机制(复用),效率更高,调试方便


备注:


计算属性最终会出现在vm上,直接读取使用即可

如果计算属性要被修改,那必须写set函数去响应修改,且set中要引起计算时依赖的数据发生改变

如果计算属性确定不考虑修改,可以使用计算属性的简写形式

new Vue({
    el:'#root', 
    data:{ 
        firstName:'张',
        lastName:'三'
    },
    computed:{
      fullName(){
        return this.firstName + '-' + this.lastName
      }
    }
})
相关文章
|
3月前
|
缓存 C++
计算属性缓存 vs 方法
计算属性缓存 vs 方法
|
3月前
|
缓存
|
2月前
|
存储 程序员 Swift
Swift开发——存储属性与计算属性
Swift推荐使用结构体进行开发,结构体支持属性和方法,且作为值类型。结构体属性包括存储属性(如radius)和计算属性(如r),计算属性不存储值,类似方法。结构体用`struct`定义,命名遵循大驼峰规则。实例名遵循小驼峰规则。属性可在结构体中任意位置定义,静态属性用`static`。存储属性可为`lazy`实现懒加载。结构体实例通过`.`访问属性和方法,静态属性和方法用`结构体名.`访问。计算属性可读写,可通过`get`和`set`定义。程序段1展示了结构体Point和Circle的属性和方法,包括私有属性、只读计算属性、可读写计算属性及`mutating`方法。
20 0
Swift开发——存储属性与计算属性
|
1月前
|
JavaScript
通过类型缩小来处理联合类型值
通过类型缩小来处理联合类型值
12 0
|
3月前
|
缓存 JavaScript 开发者
什么是vue的计算属性?为什么使用?计算属性和方法有什么区别?怎样选择
什么是vue的计算属性?为什么使用?计算属性和方法有什么区别?怎样选择
28 0
|
3月前
|
JavaScript
可写计算属性
可写计算属性
|
12月前
|
JavaScript 前端开发
计算属性和监视属性的区别
计算属性和监视属性的区别
|
3月前
|
缓存 JavaScript
computed(计算属性)
computed(计算属性)
36 0
对象的属性和值转换
对象的属性和值转换
32 0
|
缓存 JavaScript
Computed计算属性
没有使用计算属性,在 methods 里定义了一个方法实现了相同的效果,甚至该方法还可以接受 参数,使用起来更灵活。 既然使用 methods 就可以实现,那么为什么还需要计算属性呢? 原因就是计算属性是基于它的依赖缓存的。 一个计算属性所依赖的数据发生变化时,它才会重新取值,所以text 只要不改变,计算属性也就不更新
123 0
Computed计算属性