Vue 监听函数和计算函数

监听函数和计算函数:

面试题:

监听函数和计算函数的区别:

#### 监听函数只监听一个变量,计算函数可计算多个变量。

#### 监听函数是异步函数,计算函数是同步函数。

#### 监听函数不具有缓存性,页面重新渲染,值不发送变化,也会执行;

#### 计算函数具有缓存性,页面重新渲染,值不发生变化,但会返回之前的结果。
 

计算函数computed

调用时不需要()
姓:<input type="text" v-model="a"><br>
名:<input type="text" v-model="b"><br>
<span>{{fullname}}</span>
computed:{
  fullname:function(){
    return this.a + this.b;
  }
}

监听函数watch

#### 监听函数中的函数名必须和监听变量名一致

参数固定news,old  // count:function(news,old){

调用时不需要()
<input type="button" value="计算" @click="count++">
<span>{{count}}</span>
new Vue({
  el:"#app",
  data:{
  count:0,
  },
  watch:{
    count:function(news,old){
    if(news >= 6)
      this.count = 6;
    }
  },
})

过滤函数filters

<input type="text" v-model="str"><br>
<span>{{str|strfun}}</span>
new Vue({
  el:"#app",
  data:{
  str:"a"
  },
  filters:{
    strfun:function(value){
      return value.toUpperCase();

    }

  },

})

举例:

 
<body>
    <div id="app">
        姓:<input type="text" v-model="a"><br>
        名:<input type="text" v-model="b"><br>
        <span>{{full}}</span>
        <hr>
        <input type="button" value="计算" @click="count++">
        <span>{{count}}</span>
        <hr>
        <input type="text" v-model="str"><br>
        <span>{{str|strfun}}</span>
    </div>
    <script>
        var v = new Vue({
            el:"#app",
            data:{
              a:"",
              b:"",  
              count:0,
              str:"a",

            },
            filters:{
                strfun:function(value){
                    return value.toUpperCase();
                }
            },
            methods:{
            },
            watch:{
                count:function(news,old){
                   if(news >= 6)
                        this.count = 6;
                }
            },
            computed:{
                full:function(){
                    return this.a + this.b;
                }
            },
        })
        console.log(v.str)
    </script>
</body>

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值