我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue中的 watch监听属性详情

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue中的 watch监听属性详情

首先要确认 watch是一个对象,要当成对象来使用。

键:就是那个,你要监听的那个家伙;

值:可以是函数,当你监控的家伙发生变化时,需要执行的函数,这个函数有两个形参

第一个是当前值(新的值),第二个是更新前的值(旧值)

值也可以是函数名:不过这个函数名要用单引号来包裹。

值是包括选项的对象:选项包括有三个。

  • 1.第一个 handler:其值是一个回调函数。即监听到变化时应该执行的函数。
  • 2.第二个是 deep:其值是 true 或 false;确认是否深入监听。(一般监听时是不能监听到对象属性值的变化的,数组的值变化可以听到。)
  • 3.第三个是 immediate:其值是 true 或 false;确认是否以当前的初始值执行 handler 的函数。

一.watch监听一般数据的变化(数值,字符串,布尔值)

举例说明:

1.数值

data数据中心的num,当我们通过点击事件让它发生变化时,通过watch监听属性监听它的变化


<div id="app">
        <p>{{num}}</p>
        <button @click="num++">点击加一</button>
    </div>
      let vm = new Vue({
            el:'#app',
            data:{
                num:0
            },
            watch:{
            // 当前值(已经改变的值)newval  旧值 oldval
                num:function(newval,oldval){
                    console.log("新值是:"+newval);
                    console.log("旧值是:"+oldval);
                }
            }
        })


当我们点击按钮时,查看控制台:

 注意:在watch中还有其他两种方法


 watch:{
            // 当前值(已经改变的值)newval  旧值 oldval
                // num(newval,oldval){
                //     console.log("新值是:"+newval);
                //     console.log("旧值是:"+oldval);
                // }
                num:{
                    handler(newval,oldval){
                    console.log("新值是:"+newval);
                    console.log("旧值是:"+oldval);
                    }
                }
            }


输出结果是一致的,下面的例子统一使用第三种方法,也就是带handler的方法。

2.字符串


<div id="app">
        <input type="text" v-model="mes">
        <p>输入的内容为:{{mes}}</p>
    </div>
 let vm = new Vue({
            el:'#app',
            data:{
                mes:''
            },
            watch:{
                mes:{
                    handler(newval,oldval){
                        console.log("新的内容:"+newval);
                        console.log("旧的内容:"+oldval);
                    }
                }
            }
        })


当我们在文本框内输入内容时:

查看输出结果:

3.布尔值


<div id="app">
        <p v-show="isShow">通过修改布尔值显示和隐藏</p>
        <button @click="isShow = !isShow">点击改变布尔值</button>
    </div>
 

let vm = new Vue({
            el:'#app',
            data:{
                isShow:true
            },
            watch:{
                isShow:{
                    handler(newval,oldval){
                        console.log("新的值:"+newval);
                        console.log("旧的值:"+oldval);
                    }
                }
            }
        })

当点击按钮切换时,查看控制台:

二.watch 监听 复杂类型数据的变化

deep 属性:深度监听对象变化 (代表是否深度监听),当需要监听一个对象的改变时,普通的 watch 方法无法监听到对象内部属性的改变,此时就需要 deep 属性对对象进行深度监听。

1.对象


<div id="app">
        <input type="text" v-model="mes.name">
        <p>输入的内容是:{{mes.name}}</p>
    </div>
let vm = new Vue({
            el:'#app',
            data:{
                mes:{name:''}
            },
            watch: {
                mes:{
                    // watch监听属性监听对象时新旧值时相同的
                    handler(newval){
                        console.log("新值为:"+this.mes.name);
                    },
                    deep:true
                }
            }
        })


在文本框中输入内容后,查看控制台:

也可以在对象中添加num,通过滑动杆来控制num的值,并监听:


 <input type="range" v-model="mes.num">
 data:{
                mes:{name:'',num:''}
            },
 
watch: {
                mes:{
                    // watch监听属性监听对象时新旧值时相同的
                    handler(newval){
                        console.log("num新值:"+this.mes.num);
                    },
                    deep:true
                }
            }


滑动时查看输出结果:

2.数组


<body>
    
    <div id="app">
        <ul>
            <li v-for="(item,index) in arr">{{item}}</li>
        </ul>
        <!-- 添加一个按钮,点击时往数组中添加一个新内容 -->
        <button @click="add()">点击添加</button>
    </div>
 
    <script class="lazy" data-src="./js/vue.js"></script>
    <script>
        let vm = new Vue({
            el:'#app',
            data:{
                arr:[1,2,3,4,5]
            },
            methods:{
                add(){
                    // 获取当前数组最大值
                    let cont = this.arr[this.arr.length-1];
                    // 自增
                    cont++;
                    // 向数组最后一位添加元素
                    this.arr.push(cont);
                }
            },
            watch: {
                arr:{
            // 监听数组的时候不需要深度监听,不需要deep
                    handler(newval){
                        console.log("新数组为:"+newval);
                    }
                }
            }
        })
    </script>
</body>


点击添加元素后,查看输出结果:

3.对象数组


<body>
    
    <div id="app">
        <ul>
            <li v-for="item in list">
                {{item.id}}--{{item.name}}
            </li>
        </ul>
        <!-- 定义文本框,向数组中添加新的对象 -->
        <input type="text" v-model="id">
        <input type="text" v-model="name">
        <button @click="add()">添加</button>
    </div>
 
    <script class="lazy" data-src="./js/vue.js"></script>
    <script>
        let vm = new Vue({
            el:'#app',
            data:{
                list:[
                    {id:1,name:"哇哈"},
                    {id:2,name:"哇哈哈"},
                    {id:3,name:"哇哈哈哈"}
                ],
                id:"",
                name:''
            },
            methods: {
                // 将收到的输入内容添加到数组中
                add(){
                    this.list.push({id:this.id,name:this.name});
                    // 清除文本框的内容
                    this.id=this.name=''
                }
            },
            watch:{
                // 注意:watch对象中监听的数据,一定是数据中心data中已经存在的数据
                // watch监听数组对象 新,旧值是相等,但是监听数组的时候,不需要 深度监听!
                list:{
                    handler(newval){
                        newval.forEach((item)=>{
                            console.log(item.name);
                        })                       
                    }
                }
            }
        })
    </script>
</body>


添加新元素后查看输出结果:

4.对象数组的属性


<body>
    
    <div id="app">
        <ul>
            <li v-for="x in list">
                {{x.id}}---{{x.name}} &emsp;
                <button @click="mod(x.id)">修改</button>
            </li>
        </ul>
    </div>
 
    <script class="lazy" data-src="./js/vue.js"></script>
    <script>
        let vm = new Vue({
            el:'#app',
            data:{
                list:[
                    {id:1,name:'ww'},
                    {id:2,name:'ee'},
                    {id:3,name:'qq'}
                ],
            },
            methods: { 
                mod(id,name){
                    this.list.forEach((item)=>{
                        // 在遍历的过程中做判断,如果你点击的id就是你当前编辑的这一条数据
                        if(item.id == id){
                            item.name = "老铁"
                            console.log(item);
                        }
                    })
                }
            },
            watch: {
                list:{
                    handler(x,y){
                        x.forEach((element)=>{
                            console.log(element.name);
                        })
                    },
                    deep:true
                }
            }
        })
    </script>
</body>


点击修改时,查看输出结果:

到此这篇关于Vue中的 watch监听属性详情的文章就介绍到这了,更多相关Vue中的 watch监听属性内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue中的 watch监听属性详情

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue中如何watch监听属性

这篇文章主要介绍了Vue中如何watch监听属性,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。首先要确认 watch是一个对象,要当成对象来使用。键:就是那个,你要监听的那个
2023-06-21

vue怎么使用watch监听属性

这篇文章主要介绍了vue怎么使用watch监听属性的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue怎么使用watch监听属性文章都会有所收获,下面我们一起来看看吧。基本用法Vue watch最重要的使用场景
2023-06-30

vue中watch监听对象中某个属性的方法

watch的用法有个特点,就是当值第一次绑定的时候,不会执行监听函数,只有值发生改变才会执行,如果我们需要在最初绑定值得时候也执行函数,就需要用到immediate属性,这篇文章主要介绍了vue中watch监听对象中某个属性的方法,需要的朋友可以参考下
2023-05-17

关于Vue中的watch监视属性

这篇文章主要介绍了关于Vue中的watch监视属性,Vue中的watch默认不监视对象内部值的改变,当被监视的属性变化时,回调函数自动调用,进行相关操作,需要的朋友可以参考下
2023-05-17

关于Vue中的计算属性和监听属性详解

这篇文章主要介绍了关于Vue中的计算属性和监听属性详解,Vue.js模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的,在模板内放入过长的或复杂的逻辑时,会让模板过重且难以维护,需要的朋友可以参考下
2023-05-20

Vue3中怎么使用watch监听对象的属性值

这篇文章主要介绍“Vue3中怎么使用watch监听对象的属性值”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue3中怎么使用watch监听对象的属性值”文章能帮助大家解决问题。Vue3 中使用 w
2023-07-04

Vue3中watch监听对象的属性值(监听源必须是一个getter函数)

这篇文章主要介绍了Vue3中watch监听对象的属性值,监听源必须是一个getter函数,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-12-20

Vue中的计算属性与监听属性怎么用

今天小编给大家分享一下Vue中的计算属性与监听属性怎么用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、为什么要使用计算属
2023-06-29

如何理解Vue的监听属性

如何理解Vue的监听属性,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Vue监听属性什么是监听属性?所谓监听就是对内置对象的状态或者属性变化进行监听并且做出反应的响应,监听
2023-06-21

vue中watch监听不到变化的解决

本文主要介绍了vue中watch监听不到变化的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-05

编程热搜

目录