计算属性与案例

计算属性

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

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

             3.get函数什么时候执行

                  (1).初次读取时会执行一次

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

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

            5.备注:

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

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

姓名案例

<div id="root">
        姓:<input type="text" v-model="firstName"><br>
        名:<input type="text" v-model="lastName"><br>
        全名:<span>{{fullName}}</span>

    </div>
    
</body>
<script type="text/javascript">
    Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。

    const vm =new Vue({
        el:'#root',
        data:{
             firstName:'张',
             lastName:'三',
        },
        methods:{
            demo(){

            }
        },
        computed:{
            fullName:{
                //get有什么用?当有人读取fullName时 get就会被调用 且返回值就作为fullName的值
                //get什么时候调用?1.初次读取fullName时 2.所依赖的数据发生变化时 
                get(){
                    console.log('get被调用了')
                    return this.firstName + '-' + this.lastName

                },
                //set什么时候调用?  当fullName被修改时调用
                set(value){
                    console.log('set',value)
                    const arr = value.split('-')
                    this.firstName = arr[0]
                    this.lastName = arr[1]
                }
            }
        }
        
    })

修改姓和名 全名也会跟着改变 更改几次get就会被调用几次

 简写

完整写法

            fullName:{

            get(){

            console.log('get被调用了')

            return this.firstName + '-' + this.lastN

 }

                set(value){

                  console.log('set',value)

                    const arr = value.split('-')

                    this.firstName = arr[0]

                   this.lastName = arr[1]

               }

            }

   简写 只考虑读取不考虑修改的时候才能用简写

         fullName(){

                    console.log('get被调用了')

                    return this.firstName + '-' + this.lastName

            }

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js计算属性可以在Vue实例中定义一个计算属性,它根据依赖的数据进行计算,并返回计算结果。以下是一个Vue计算属性案例。 在这个案例中,我们使用Vue.js创建了一个简单的金额计算器。页面上有两个输入框分别用于输入单价和数量,并显示了运费和总金额。计算属性`sum`根据输入的单价和数量计算出总金额,并根据总金额的大小决定运费的显示。如果总金额大于88,则不显示运费,否则显示运费为10。重要的是,在每次输入框的值发生变化时,计算属性会自动重新计算。 以下是Vue计算属性案例代码: ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script src="vue.js" type="text/javascript" charset="utf-8"></script> </head> <body> <div id="out"> <h1>金额</h1> <div> 单价: <input v-model='price' type="text" /> </div> <div> 数量: <input v-model="count" type="text" /> </div> <div> 运费:{{yunfei}} </div> <div> 总金额:{{sum}} </div> </div> </body> <script type="text/javascript"> var vm=new Vue({ el:"#out", data:{ price:'', count:'', yunfei:10 }, computed:{ sum(){ if(this.price*this.count>88){ this.yunfei=0 }else{ this.yunfei=10 } return this.price*this.count + this.yunfei } } }) </script> </html> ``` 在这个案例中,我们使用Vue的`v-model`指令将输入框与Vue实例中的数据绑定起来,这样当输入框的值发生变化时,对应的数据也会自动更新。计算属性`sum`根据输入的单价和数量计算出总金额,并根据总金额的大小决定运费的显示。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值