vue中watch是什么属性

watch是监视属性。在vue中,可以通过watch属性来监视某个属性的变化,当这个属性发生变化时,可以执行一些操作:1、当监视属性所监视的属性发生变化的时候,回调函数就会自动调用,并且执行相关的操作;2、监视属性所监视的属性要存在,才能产生作用。监视属性有两种写法“new Vue({watch:{}})”和“vue实例化对象.$watch(‘属性名’回调函数)”。

vue中watch是什么属性

本教程操作环境:windows7系统、vue3版,DELL G3电脑。

vue监视属性

在开发中,我们会遇到这样一种情况,我们需要一个属性变化的时候,然后做出一些操作。而检测这个变化的属性,在vue中叫做监视属性。

1.监视属性是什么

在vue中,我们可以通过watch属性来监视某个属性的变化,当这个属性发生变化时,我们可以执行一些操作。

立即学习“前端免费学习笔记(深入)”;

当监视属性所监视的属性发生变化的时候,回调函数(handler)就会自动调用,并且执行相关的操作监视属性所监视的属性要存在,才能产生作用。

我们这里用一个天气案例来解释什么是监视属性:

首先html代码:

    
        

今天天气很{{info}}

            

登录后复制

接下来我们书写js代码:

    var vm = new Vue({        el: "#app",        data: {            isHot: true,        },        computed: {            info: function () {                return this.isHot ? "热" : "冷";            }        },        methods: {            change: function () {                this.isHot = !this.isHot;            }        },        watch: {            isHot: {                handler:function (newVal, oldVal) {                    console.log("isHot属性发生了变化");                },            }        }    });

登录后复制

在代码里面的handler这个函数就是我们前面说的回调函数,当isHot属性发生变化的时候,这个函数就会自动调用。

当然我们可以在idHot对象面添加一个属性:immediate,当此属性布尔值为真的时候,handler回调函数在初始化的时候就会调用一次。

    watch: {        isHot: {            handler:function (newVal, oldVal) {                console.log("isHot属性发生了变化");            },            immediate: true        }    }

登录后复制

2.监视属性的写法

监视属性有两种写法:

在vue实例化对象中直接书写:
new Vue({watch:{}}),然后传入相关配置通过vue实例化对象.$watch(‘属性名’,回调函数)来书写

这里的第一种写法上面我们已经展现过了,下面我们就展示一下第二种写法:

这里我们假设vue的实例化对象为vm。

    vm.$watch('isHot',function (newVal, oldVal) {        console.log("isHot属性发生了变化");    });

登录后复制

3.监视属性之深度监视

前面我们实现的监视,只能监视vue实例data中直接的简单数据,要是遇到对象或者数组,就无法监视了。

这样做的方法是vue为了提高效率,在vue监视属性中,默认只监视一层,如果要监视多层,就需要我们手动开启深度监视。

    watch: {        isHot: {            handler:function (newVal, oldVal) {                console.log("isHot属性发生了变化");            },            immediate: true,            deep: true        }    }

登录后复制

其中deep:true就开启了深度监视。深度监视就是监视vue中data中的对象或者数组,当对象或者数组中的属性发生变化的时候,监视属性的回调函数就会自动调用。

在vue中其实是可以检测对象内部值的变化,那为什么vue监视属性不默认开启深度监视呢?

因为vue监视属性的回调函数是在数据发生变化的时候才会调用,如果开启深度监视,那么vue就要监视对象内部的所有属性,这样会大大降低vue的效率。

在我们使用监视属性的时候,我们根据具体的业务需求,来判断要不要开启深度监视。【相关推荐:vuejs视频教程、vuejs视频教程】

以上就是vue中watch是什么属性的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2923487.html

(0)
上一篇 2025年3月11日 18:48:19
下一篇 2025年3月5日 20:14:49

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • vue中什么是模块化

    在vue中,模块化就是把单独的一个功能封装到一个模块(文件)中,模块之间相互隔离,但是可以通过特定的接口公开内部成员,也可以依赖别的模块(方便代码的重用,从而提升开发效率,并且方便后期的维护)。模块化开发的好处:1、条理清晰,便于维护;2、…

    2025年3月11日
    200
  • vue 怎么隐藏内容

    vue隐藏内容的方法:1、在所需要隐藏或显示的内容div加“v-show”;2、在iconfont图标的div加入一个点击事件;3、在×处用transition包裹,并添加name属性;4、为fade添加效果样式即可。 本教程操作环境:Wi…

    2025年3月11日
    200
  • vue sync出错怎么办

    vue sync出错的解决办法:1、修改父组件传过来的数据,代码如“”;2、把需要传递的基本数据类型值放入对象中,代码如“”。 本教程操作环境:Windows10系统、Vue 3版、Dell G3电脑。 vue sync出错怎么办? Vue…

    2025年3月11日
    200
  • vue初始化data方法有哪些

    vue初始化data方法有两种:1、object方式,语法“var data = { 键值对 }”;2、function方式,语法“data: function () {return { 键值对 }}”。需要注意组件和extend中的dat…

    2025年3月11日
    200
  • vue条件渲染包括什么

    vue条件渲染指令包括v-if、v-else、v-else-if、v-show。v-if指令用于条件性地渲染一块内容,这块内容只会在指令的表达式返回真值时才被渲染;v-else可以为v-if添加一个“else 区块”,v-else-if可以…

    2025年3月11日 编程技术
    200
  • vue中mvvm和mvc的区别有哪些

    mvvm和mvc的区别:1、mvvm各部分的通信是双向的,而mvc各部分通信是单向的。2、MVVM实现了view与model的自动同步,也就是model属性改变时,不需要手动操作dom元素去改变view的显示,而是改变属性后该属性对应的vi…

    2025年3月11日 编程技术
    200
  • 用vue写的页面后缀名是什么

    用vue写的页面后缀名是“.vue”。“.vue”文件是一个自定义的文件类型,用类HTML语法描述一个Vue组件;一个vue文件就是一个组件。vue页面有3个组成部分:1、模板(template),即template标签包裹的界面展示代码(…

    2025年3月11日 编程技术
    200
  • vue遍历对象属性的方法有哪些

    遍历对象属性的方法有:1、使用v-for指令遍历出对象的key和value,语法“v-for=”(val,key,i) in obj””;2、用Object.keys()遍历对象的键和值,语法“Object.keys…

    2025年3月11日 编程技术
    200
  • vue事件总线废除了吗

    vue3取消了全局事件总线,废除原因是安全性低。全局事件总线是一个全局任意组件通信技术,即任意组件间的通信均可实现。在vue3中,如果想要使用全局事件总线,需要引入第三方库mitt或tiny-emitter。 本教程操作环境:windows…

    2025年3月11日
    200
  • vue支持ie6么

    vue不支持ie6;vue官方声明是支持ie8以上版本的。不支持原因:1、ie8及以下版本不支持“Object.defineProperty”方法,但该方法是vue实现响应式的所必须的;2、Vue需要Promise的支持,而IE8及以下版本…

    2025年3月11日
    200

发表回复

登录后才能评论