Detailed explanation of Vue's monitoring method case

Detailed explanation of Vue's monitoring method case

Monitoring method in Vue

watch

Notice

Name: You should give the same name to the attribute you want to monitor.

1. Function

Used to monitor data changes in the vue instance and modify state changes at any time

2. Trigger conditions

When the property you monitor changes, the corresponding monitoring method will be called automatically

3. Usage scenarios

Used for asynchronous processing and relatively expensive operations

4. Examples

	 watch:{
             name(newvalue,oldvalue){
                  //Calculated properties can accept two parameters, the first parameter is the new property value, the second parameter is the old property value // this.age
                    // console.log('name property has changed')
                    console.log(newvalue,oldvalue)
                }

5. When monitoring an object

<script>
export default {
    data() {
        return {
            obj: {
                name: "Zhang San",
                age: 20,
                children: [
                    {
                        name: "Li Si",
                        age: 27
                    },
                    {
                        name: "Wang Wu",
                        age: 23
                    }
                ]
            }
        };
    },
    watch:
        obj: {
            handler: function(newVal, oldVal) {
                console.log("newVal:", newVal);
                console.log("oldVal:", oldVal);
            },
            deep: true,
            immediate: true
        },
        "obj.name": function(newVal, oldVal) {
            
            console.log("newVal obj.name:", newVal);
            console.log("oldVal obj.name:", oldVal);
        }
    },
};
</script>

When monitoring an object, you need to add deep:true so that you can monitor it in real time at the bottom layer. If you don’t add it, the object will not be able to monitor changes.

immediate attribute: Boolean value
immediate: true: monitor data changes when loading for the first time
immediate: false: listen only when changes occur

deep:true;

It turns on deep listening, that is, listeners are added to all attributes, and the handler function is executed if one of them changes.

This is the end of this article about the detailed case of Vue's monitoring method. For more relevant Vue's monitoring method content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • A brief analysis of the use of watchEffect in Vue3
  • Usage and best practice guide for watch in Vue3
  • Summary of the use of vue Watch and Computed
  • How to understand the difference between computed and watch in Vue
  • Solution to the problem of repeated triggering of functions in Vue project watch
  • Reasons and solutions for multiple executions of the watch method when Vue monitors route changes
  • The use and difference between vue3 watch and watchEffect
  • Simple method example of vue watch monitoring object

<<:  MySQL 5.7 installation and configuration tutorial under CentOS7 64 bit

>>:  CentOS 6 uses Docker to deploy redis master-slave database operation example

Recommend

How to define input type=file style

Why beautify the file control? Just imagine that a...

Implementation of static website layout in docker container

Server placement It is recommended to use cloud s...

Introduction to Apache deployment of https in cryptography

Table of contents Purpose Experimental environmen...

Mybatis implements SQL query interception and modification details

Preface One of the functions of an interceptor is...

Detailed explanation of Angular component projection

Table of contents Overview 1. Simple Example 1. U...

Do you know all 24 methods of JavaScript loop traversal?

Table of contents Preface 1. Array traversal meth...

Detailed explanation of mysql integrity constraints example

This article describes the MySQL integrity constr...

Sample code for using CSS to write a textured gradient background image

The page length in the project is about 2000px or...

How to run top command in batch mode

top command is the best command that everyone is ...

How to collect Nginx logs using Filebeat

Nginx logs can be used to analyze user address lo...

In-depth understanding of Vue's plug-in mechanism and installation details

Preface: When we use Vue, we often use and write ...

Detailed graphic tutorial on installing and uninstalling Tomcat8 on Linux

[ Linux installation of Tomcat8 ] Uninstall Tomca...