姓名案例中method与computed的区别

1.是否加括号。method是方法,在插值语法{{}}中fullName作为一个返回值所以必须为{{fullName()}},而computed作为计算属性不用加

(ps:在事件绑定中()加不加都可以,想传参数时可以加但是加了事件对象event就没有了,除非使用$event去占位)

<!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>Document</title>
    <script src="../js/vue.js"></script>
</head>

<body>
    <div id="root">
        姓:<input type="text" v-model="firstName"><br>
        名:<input type="text" v-model="lastName"><br>

        全名:<span>{{fullName()}}</span>
    </div>
</body>
<script>
    new Vue({
        el: '#root',
        data: {
            firstName: '小猪',
            lastName: '佩奇'

        },
        methods: {
            fullName() {
                return this.firstName + '-' + this.lastName
            }
        }
    })
</script>

</html>
<!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>Document</title>
    <script src="../js/vue.js"></script>
</head>

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

    </div>
</body>
<script>
    const vm = new Vue({
        el: '#root',
        data: {
            firstName: '小猪',
            lastName: '佩奇',
            x: '2'

        },
        computed: {
            fullName: {
                get() {
                    //get有什么作用?当有人读取fullName时,get就会被调用,且返回值就作为fullName的值
                    //get什么时候调用?1.初次读取fullName时。2.所依赖的数据发生变化时。
                    console.log('get被调用');//get只有一次,其余为缓存
                    return this.firstName + '-' + this.lastName
                },
                //set什么时候调用?1.fullName被修改时。2.所依赖的数据发生变化时。
                set(value) {
                    console.log('set', value);
                    const arr = value.split('-')
                    this.firstName = arr[0]
                    this.lastName = arr[1]
                }
            }
        }
    })
</script>

</html>

2.是否存有缓存。methods没有缓存,调用相同的值计算还是会重新计算。competed有缓存,在值不变的情况下不会再次计算,只有当关联属性发生变化时,才会重新调用。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值