Vue技术8.3姓名案例_计算属性实现

<!DOCTYPE html>>
<html>
    <head>
        <meta charset="UTF-8" />
        <title>姓名案例_计算属性实现</title>
        <!-- 引入Vue -->
        <script type="text/javascript" src="../js/vue.js"></script>
    </head>
    <body>
        <!--
            计算属性:
                1.定义:要用的属性不存在,要通过已有属性计算得来。
                2.原理:底层借助了Object.defineproperty方法提供的getter和setter。
                3.get函数什么时候执行?
                    (1)初次读取时会执行一次;
                    (2)当依赖的数据发生改变时会被再次调用。
                4.优势:与methods实现相比,内部有缓存机制(复用),效率更高,调试方便。
                5.备注:
                    (1)计算属性最终会出现在vm上,直接读取使用即可。
                    (2)如果计算属性要被修改,那必须写set函数去响应修改,且set中要引起计算时依赖的数据发生改变。
        -->
        <!-- 准备好一个容器 -->
        <div id="root">
            姓:<input type="text" v-model="lastname"><br/><br/>
            名:<input type="text" v-model="firstname"><br/><br/>
            全名:<span>{
   
   {fullname}}</span>

        </div>
    </body>

    <script type="text/javascript">
        Vue.config.productionTip = false
        
        const vm = new Vue({
      
      
            el:'#root',
            data:{
      
      
                lastname:'张',
                firstname:'三'
            },
            computed:{
      
      
                fullname:{
      
      
                    //get有什么作用?当有人读取fullname时,get就会被调用,且返回值就作为fullname的值
                    get(){
      
      
                        console.log('get被调用了')
                        console.log(this)
                        return this.lastname + '-' + this.firstname
                    },
                    set(value){
      
      
                        console.log('set',value)
                        const arr = value.split('-')
                        this.lastname = arr[0]
                        this.firstname = arr[1]
                    }
                }
            }
        })
    </script>
</html>

猜你喜欢

转载自blog.csdn.net/qq_40713201/article/details/126168152