数组的侦听

本文介绍了Vue.js中如何使用侦听器监听数组变化。Vue.js对数组做了特殊处理,能够侦听到使用标准方法如push(), pop(), unshift(), shift(), splice(), sort(), reverse()对数组的修改。然而,直接通过索引赋值或改变数组长度的方式无法被侦听,建议使用$set()方法或标准操作方法来确保视图更新。" 93893923,5891514,深入理解Spring Cloud Feign:Hystrix支持与源码解析,"['Spring Cloud', 'Feign', 'Hystrix', '服务调用', '代理']
摘要由CSDN通过智能技术生成

1.侦听器的基本结构

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

语法:在和data、methods这些平级的位置写一个watch

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

                }
            }
        })
    </script>

对数组进行侦听

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

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

    1.Vue不能检测以下数组的变动:

    a.当你利用索引值直接设置一个数组时,例如:vm.items[index0fItem] = newValue

    b.当你修改数组的长度时,例如:vm.items.length = newlength

    2.使用标准方法修改数组可以被侦听到

https://v2.cn.vueis.org/v2/guide/list.html#%E6%95%B0%E7%BB%84%E6%9B%B4%E6%96%B0%E6%A3%80%E6%B5%8B

    push() 尾部添加

    pop()尾部删除

    unshift()头部添加

    shift()头部删除

    splice()删除、添加、替换

    sort()排序

    reverse()逆序

    (Vue将被侦听的数组的变更方法进行了包裹,所以它们也将会触发视图更新,以上就是被包裹的方法。)

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>
<!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>
</head>
<body>
    <div id="app">
        <button @click="list.push('蜡笔小新')">添加一个项</button>
        <button @click="list.pop()">删除一个项</button>
        <!-- 利用索引值改变数组时,不能被侦听到 -->
        <button @click="list[0] = '病猫' ">修改第一项</button>
        <button @click="list.splice(1,0,'天气之子')">第二项添加</button>
        <ul>
            <li v-for="item in list">
                {{item}}
            </li>
        </ul>
    </div>

    <script src="../vue.js"></script>

    <script>
        new Vue({
            el:'#app',
            data:{
                list:['龙猫','哈尔的移动城堡','千与千寻','你的名字']
            },
            watch:{
                //侦听list的改变
                list(){
                    console.log('数组改变了');

                    //把数据存到本地存储
                    //本地存储只能存字符串,复杂类型要转成JSON字符串才能存储
                    window.localStrage.setItem('note',JSON.stringify(this.list))
                }
            }
        })
    </script>
</body>
</html>

 在数组中使用侦听器总结:

    1.彻底替换为一个新数组,那么可以被侦听到。

    2.如果使用了push()等标准的数组操作方法,那么可以被侦听到。

    3.如果直接修改数组的元素,那么无法被侦听到。

      (解决方法:使用$set(()方法修改元素的值。Vue3语法。)

       不要使用length属性来修改数组长度,而改用其他标准方法显示数组长度的变化。

3.侦听器的完整写法

<body>
    <!-- 对对象进行侦听 -->
    <div id="app">
        <p></p>
    </div>

    <script src="../vue.js"></script>

    <script>
        new Vue({
            el:'#app',
            data:{
                obj:{
                    name:'jack',
                    age:17,
                    height:180
                }
            },
            watch:{
                // 这种写法侦听不到obj对象内部属性的变化,
                // 只能侦听到obj对象指向的变化。
                // obj(){
                // console.log('obj变化了'); 
                // },

                // 如果想侦听到对象里属性的变化.
                // 侦听obj里name的变化(要记得加引号)
                // "obj.name"(){
                // console.log('name变化了'); 
                // },

                // 可是这样写只能侦听一个属性。
                //如果希望侦听到对象里所有属性的变化,就要开启深度侦听。
                obj:{
                    handler(){
                        console.log('obj的属性变化了');
                    },

                    // 开启深度侦听
                    deep:true,

                    //要不要当前页面一打开就立即调用handler函数。
                    // 给true表示立即调用,默认是flase。(代表只有改动了才调用
                    immediate:true
                }
            }
        })
    </script>
</body>

4.侦听器在数组中的使用

<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>

   【对数组进行侦听】

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

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

    1.Vue不能检测以下数组的变动:

    a.当你利用索引值直接设置一个数组时,例如:vm.items[index0fItem] = newValue

    b.当你修改数组的长度时,例如:vm.items.length = newlength

    2.使用标准方法修改数组可以被侦听到

    https://v2.cn.vueis.org/v2/guide/list.html#%E6%95%B0%E7%BB%84%E6%9B%B4%E6%96%B0%E6%A3%80%E6%B5%8B

    push() 尾部添加

    pop()尾部删除

    unshift()头部添加

    shift()头部删除

    splice()删除、添加、替换

    sort()排序

    reverse()逆序

    (Vue将被侦听的数组的变更方法进行了包裹,所以它们也将会触发视图更新,以上就是被包裹的方法。)

   

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值