Detailed explanation of various methods of Vue component communication

Detailed explanation of various methods of Vue component communication

When it comes to component communication, there are probably five types that are familiar to everyone:

1. From father to son

The parent component passes values ​​to the child component through custom attributes, and the child component receives them using props

2. From son to father

The parent component customizes the event on the child component tag, and the child component triggers the custom event through $emit and can pass parameters

3. Non-parent-child component value transfer

eventBus event bus:

Information can be published and subscribed through eventBus (creating an event bus that everyone can access)

insert image description here

4. vuex

Vuex is a state management mode developed specifically for Vue.js applications. It uses a centralized storage manager to manage the status of all components of the program and solve multi-component communication. However, it is mostly used in medium and large projects, and it will appear bloated in small projects.

5. Refs

By adding ref and ·$refs·, you can also easily get the child component and access the properties and methods of the child component. Regarding refs, I have also written a separate article with detailed usage, the usage of refs

In addition to the above 5, there are 5 less common component communication methods:

6. $children

In the parent component, $children returns a component collection. If you know the order of the child components, you can also use the subscript operation

insert image description here

7. $parent

In the child component this.$parent points to the parent component. The child component cannot directly modify the data in the parent component. You can use this.$parent to let the parent component modify it itself.

For example:

this.$parent.xxx=200

this.$parent.fn()

8. provide & inject

Appear in pairs : provide and inject appear in pairs

Function : Used by parent components to pass data to descendant components

Directions:

  • Provide in the parent component, returns the data to be passed to the subordinate
  • inject injects data into descendant components that need to use this data. (regardless of how deep the component hierarchy is)

insert image description here

9. $attrs

Used by parent components to pass data to grandchild components

10. $listeners

Used by grandchild components to pass data to parent components

insert image description here

Summarize

This article ends here. I hope it can be helpful to you. I also hope you can pay more attention to more content on 123WORDPRESS.COM!

You may also be interested in:
  • Detailed explanation of custom events of Vue components
  • Detailed explanation of value transfer between parent and child components in Vue3
  • Vue components dynamic components detailed explanation
  • Detailed explanation of the use of Vue image drag and drop zoom component
  • Detailed explanation of the use of router-view components in Vue
  • Detailed explanation of Vue components

<<:  Docker5 full-featured harbor warehouse construction process

>>:  Introduction to the use of data custom attributes in HTML and plug-in applications

Recommend

Several ways to shut down Hyper-V service under Windows 10

When using VMware Workstation to open a virtual m...

MySQL extracts Json internal fields and dumps them as numbers

Table of contents background Problem Analysis 1. ...

How to use sed command to efficiently delete specific lines of a file

Preface Normally, if we want to delete certain li...

Compile CPP files using G++ in Ubuntu

When I used g++ to compile the cpp file for the f...

HTML Frameset Example Code

This article introduces a framework made by Frame...

What is Software 404 and 404 Error and what is the difference between them

First of all, what is 404 and soft 404? 404: Simpl...

Nginx reverse proxy to go-fastdfs case explanation

background go-fastdfs is a distributed file syste...

React Router V6 Updates

Table of contents ReactRouterV6 Changes 1. <Sw...

How to modify the "Browse" button of the html form to upload files

Copy code The code is as follows: <!DOCTYPE HT...

4 ways to modify MySQL root password (summary)

Method 1: Use the SET PASSWORD command First log ...

Writing a rock-paper-scissors game in JavaScript

This article shares the specific code for writing...

js dynamically adds example code for a list of circled numbers

1. Add the ul tag in the body first <!-- Unord...

JavaScript to implement click to switch verification code and verification

This article shares the specific code of JavaScri...