Life cycle and hook functions in Vue

Life cycle and hook functions in Vue

1. What is the life cycle

A Vue instance has a complete life cycle, which includes a series of processes such as creation, data initialization, template compilation, Dom mounting, rendering → updating → rendering, and uninstallation. We call this the life cycle of Vue. In simple terms, the process from creation to destruction of a Vue instance is the life cycle.

Throughout the life cycle of Vue, it provides a series of events that allow us to register js methods when events are triggered, allowing us to control the overall situation with our own registered js methods. In these event response methods, this directly points to the vue instance.

2. The life cycle of Vue

Life cycle function, also called hook function (life cycle hook === life cycle function === life cycle event)

The life cycle functions in Vue usually appear in pairs. So we compare them in pairs and see the difference between them.

10 life cycle functions to remember! Specific use!

3. Lifecycle hook function

Features: Automatically called, but their calling time nodes are different.

I took a picture from the official website:

beforeCreate --- "before creation" of the Vue instance. Note: In this function, the data in the data center of Vue cannot be read.

  <script src="./js/vue.js"></script>
    <script>
        let vm = new Vue({
            el:'#app',
            data:{
                name:"Hahaha",
                num:1111
            },
            methods: {
                
            },
 
            // Before the vue instance is created beforeCreate(){
                console.log('beforeCreate');
                console.log(this.name);
            }
    </script>


The name of the output data center cannot be read:

created --- After the vue instance is created, note: in this function, the data in the data center of vue can be identified <script src="./js/vue.js"></script>
    <script>
        let vm = new Vue({
            el:'#app',
            data:{
                name:"Hahaha",
                num:1111
            },
            // After the vue instance is created created(){
                console.log("created");
                console.log(this.name);
            }
        })
    </script>


View the results:

beforeMount --- DOM is mounted this.$el---$el at this time is a "virtual" DOM ​​node

Render the label at the view level:

  <div id="app">
        <p>{{name}}</p>
        <p>{{num}}</p>
    </div>
<script src="./js/vue.js"></script>
    <script>
        let vm = new Vue({
            el:'#app',
            data:{
                name:"Hahaha",
                num:1111
            },
            //Before dom is mounted beforeMount(){
                console.log("beforeMount");
                   //View DOM elements console.log(document.body.querySelector("#app").innerHTML);
            }
        })
    </script>


Output results before dom mounting:

 mounted --- after DOM is mounted this.$el --- at this time $el is the "real" DOM ​​node <script src="./js/vue.js"></script>
    <script>
        let vm = new Vue({
            el:'#app',
            data:{
                name:"Hahaha",
                num:1111
            },
            // After dom is mounted mounted(){
                console.log("mounted");
                console.log(document.body.querySelector("#app").innerHTML);
            }
        })
    </script>


View the output:

  • beforeUpdate --- Before data is updated (---- before and after changes in data in the view layer)
  • updated --- After the data is updated (----the changes before and after the data in the view layer)

In the view layer, click to change the value of num to simulate data update and view the result:

  
    <div id="app">
        <p id="num">{{num}}</p>
        <button @click="num++">Click data update (num+1)</button>
    </div>
  //Before data update beforeUpdate(){
                console.log("beforeUpdate--before data update");
                // View DOM elements console.log(document.body.querySelector("#num").innerHTML);
            },
            //After data is updated updated(){
                console.log("updated--After data updated");
                // View DOM elements console.log(document.body.querySelector("#num").innerHTML);
            }


At this time, when the data does not change, the effect cannot be seen in the console. When we click the button:

This is the end of this article about the life cycle and hook functions in Vue. For more information about the life cycle hook functions in Vue, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Introduction to Vue life cycle and detailed explanation of hook functions
  • Detailed explanation of Vue3 life cycle hook function
  • How many stages are there in the Vue life cycle? What are the differences?
  • Let's talk about the vue life cycle hook functions and when they are triggered

<<:  Hide HTML elements through display or visibility

>>:  A brief analysis of the relationship between various Tomcat logs and the segmentation of catalina.out files

Recommend

How to use ssh tunnel to connect to mysql server

Preface In some cases, we only know the intranet ...

WeChat Mini Program Lottery Number Generator

This article shares the specific code of the WeCh...

Detailed explanation of MySQL remote connection permission

1. Log in to MySQL database mysql -u root -p View...

How to reset the root password in Linux mysql-5.6

1. Check whether the MySQL service is started. If...

Details of the order in which MySQL reads my.cnf

Table of contents The order in which MySQL reads ...

Solution to Linux server graphics card crash

When the resolution of the login interface is par...

JavaScript imitates Taobao magnifying glass effect

This article shares the specific code for JavaScr...

HTML exceeds the text line interception implementation principle and code

The HTML code for intercepting text beyond multipl...

How to configure two or more sites using Apache Web server

How to host two or more sites on the popular and ...

Nginx anti-crawler strategy to prevent UA from crawling websites

Added anti-crawler policy file: vim /usr/www/serv...

Summary of horizontal scrolling website design

Horizontal scrolling isn’t appropriate in all situ...

What is ssh? How to use? What are the misunderstandings?

Table of contents Preface What is ssh What is ssh...

Detailed explanation of how to easily switch CSS themes

I recently added a very simple color scheme (them...

Detailed explanation of how to solve the problem of too long content in CSS

When we write CSS, we sometimes forget about the ...

echars 3D map solution for custom colors of regions

Table of contents question extend Solving the pro...