数组的侦听

1.侦听器的基本结构:

<script>
        new Vue({
            el:'',
            data:{},
            methods:{},
            //侦听器
            watch:{
                //参数一:改变后的值
                //参数二:改变前的值
                要侦听的数据(newValue,oldValue){
 
                }
            }
        })
    </script>

作用:用来侦听数据有没有变化,一旦有变化就调用函数

数组是应用类型,存在比较复杂的侦听规则。

    从理论上说,修改一个数组的内容,比如修改数组中某个元素的值,或者给数组添加新的元素,都不会修改数组本身的地址。为此.Vue.is对数组做了特殊处理,使得使用标准的数组操作方法对数组所做的修改,都可以被侦听到。

2.侦听器的基本使用:

<body>
    <div id="app">
        <button @click="msg= '再见' ">修改msg的值</button>
        <p>{{ msg }}</p>
    </div>
    <script src="../vue.js"></script>
 
    <script>
        new Vue({
            el:'#app',
            data:{
                msg:'你好'
            },
            //写侦听器的地方
            watch:{
                //侦听的数据变化
                //基本数据类型,这两个参数有意义
                msg(newValue,oldValue){
                    //侦听到数据变化之后,需要完成的行为
                    console.log('数据改变了',newValue,oldValue);
                }
            }
        })
    </script>
</body>

3.侦听器在数组中使用:

<body>
    <div id="app">
        <li v-for="item in list">
            {{item}}
        </li>
        <ul>
            <button @click="list.push('蜡笔小新')">添加一个项</button>
        </ul>
    </div>
    <script src="../vue.js"></script>
    <script>
        new Vue({
            el:'#app',
            data:{
                list:['千与千寻','哈尔的移动城堡','龙猫']
            },
            watch:{
                //复杂数据类型,这两个参数没有意义,因为地址没变。
                //所以复杂类型中,一般不会写这两个参数,因为这两个参数的值是一样的,就算写也是写一个。
                list(newValue,oldValue){
                    console.log('数组改变了',newValue,oldValue);
                }
            }
        })
    </script>
</body>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值