计算属性 vue.js

        本文用两个input输入框来输入字符,实时获取并输出其合并在一起的内容来作为例子讲解。

1. 直接获取data中的数据将其合并:

<body>
    <div class="demo">
        <input type="text" v-model="firstName">
        <input type="text" v-model="lastName">
        <h2>{{firstName+lastName}}</h2>
    </div>


    <script>
        var demo = new Vue({
            el: '.demo',
            data: {
                firstName: '张',
                lastName: '三'
            }
        })
    </script>
</body>

        输出的结果是这样的

         通过v-model来建立数据的双向绑定,实时的更新firstName和lastName,并将其进行合并输入。

2.通过methods将其合并

<body>
    <div class="demo">
        <input type="text" v-model="firstName">
        <input type="text" v-model="lastName">
        <h2>{{add()}}</h2>
    </div>


    <script>
        var demo = new Vue({
            el: '.demo',
            data: {
                firstName: '张',
                lastName: '三'
            },
            methods: {
                add() {
                    name = this.firstName + this.lastName
                    return name
                }
            }
        })
    </script>
</body>

        运用方法将this.firstName和this.lastName合并在一起并返回,调用方法时就能得到合并的值 了。

3.运用计算属性来实现合并:

<body>
    <div class="demo">
        <input type="text" v-model="firstName">
        <input type="text" v-model="lastName">
        <h2>{{name}}</h2>
    </div>


    <script>
        var demo = new Vue({
            el: '.demo',
            data: {
                firstName: '张',
                lastName: '三'
            },
            computed: {
                name: {
                    get() {
                        return this.firstName + this.lastName
                    }
                }
            }
        })
    </script>
</body>

        此时的this是指向的demo,所以可以在get中获取到firstName和lastName

        计算属性和方法看起来类似,但各有千秋,如计算属性中的get的调用时间:

                1.name初次被调用时。

                2.name所依赖的数据发生了改变时。

        这是由于在初次调用时对数据进行了缓存,所以不会反复调用,而如果将他写在方法中,那么执行一次就会调用一次,不会进行缓存。

4.计算属性的简写方法:

<body>
    <div class="demo">
        <input type="text" v-model="firstName">
        <input type="text" v-model="lastName">
        <h2>{{name}}</h2>
    </div>


    <script>
        var demo = new Vue({
            el: '.demo',
            data: {
                firstName: '张',
                lastName: '三'
            },
            computed: {
                name() {
                    return this.firstName + this.lastName
                }
            }
        })
    </script>
</body>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值