Vue_8:计算属性

<body>
    <!--名字案例_插值语法实现-->
    <div id="root">
        姓:<input type="text" v-model="firstName"><br/>
        名:<input type="text" v-model="lastName"><br/>
        姓名:<span>{{firstName.slice(0,3)}} - {{lastName}}</span>
    </div>
</body>
    
<script type="text/javascript">
    new Vue({
        el:'#root',
        data:{
            firstName:'张',
            lastName:'三'
        }
    })
</script>
<body>
    <!--名字案例_methods语法实现-->
    <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">
    new Vue({
        el:'#root',
        data:{
            firstName:'张',
            lastName:'三'
        },
        methods:{
            fullName(){
                return this.firstName + '-' + this.lastName    
            }
            
        },
    })
</script>
<body>
    <!--名字案例_计算属性实现-->
    <!--
        计算属性:
            1.定义:要用的数据不存在,需要通过已有的属性计算得来
            2.原理:底层借助Object.defineProrerty方法提供的getter和setter实现
            3.get函数什么时候被执行
                (1)初次赋值时
                (2)所依赖的数据发生改变时
            4.优势:与methods方法相比,内部有缓存机制(复用),效率更高,调试方便
            5.备注:
                1.计算属性最终会出现在vm上,直接读取使用即可
                2.如果计算属性要被修改,那么必须调用setter去响应修改,且set中要引起计算时依赖的数据发生改变
    -->
    <div id="root">
        姓:<input type="text" v-model="firstName"><br/>
        名:<input type="text" v-model="lastName"><br/>
        姓名:<span>????</span>
    </div>
</body>
    
<script type="text/javascript">
    new Vue({
        el:'#root',
        data:{
            firstName:'张',
            lastName:'三'
        },
        computed:{
            fullName:{
                //get有什么用:当有人调用fullName时,get会被调用,返回值时fullName的值
                //get在什么时候会被调用:1.初次赋值时2.所依赖的数据发生改变时
                get(){
                    return this.firstName + '-' + this.last.Name
                }
                //set什么时候会被调用,当fullName被修改时
                set(value){
                    const arr = value.spit('-')
                    this.firstName = arr[0]
                    this.lastName  = arr[1]
                }
            }
        }
    })
</script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值