Simple use of Vue bus

Simple use of Vue bus

Simple use of Vue bus

Scenario description:

Component A includes components B and C, and component B includes component D. What if component D wants to trigger the method of component C in component A?

Of course there are solutions, you can use vuex to manage the state, or you can use $emit to pass it, but I want to try the bus method;

as follows:

The emit of the bus is triggered in the D component, and then the on of the bus is used to trigger the method in the A component;

In component D

dataLoad(){
   console.log('Loading complete trigger event');
   this.$bus.$emit('itemDataLoad') 
   // this.$bus.$emit('event name', parameter) // The second one can be a parameter},

In component A

 mounted() {
    // Listen for data loading in item this.$bus.$on('itemDataLoad', () => {
      console.log('Data loading completed');
    })
    // this.$bus.$on('event name', callback function (parameters))
  },

Of course, in component A, events in component C can be triggered by this.$refs , etc.

Another step is that $bus does not exist by default. Try printing this.$bus為undefined .

Don't worry, add $bus in main.js;

// bus bus vue instance Vue.prototype.$bus = new Vue()

Of course, the bus can be removed during the life cycle;

this.$bus.$off();

Record encapsulated anti-shake function

// debounce function: function (fun, delay) {
    let timer = null
    // Receive the value of the parameter passed in when calling the function... args can be multiple return function (...args) {
      if (tiemr) return
      timer = setTimeout(() => {
        fun.apply(this, args)
      }, delay);
    }
  }

const refresh = debounce(xxx, 500)

refresh('parameter 1', 'parameter 2', 'parameter 3')

This is the end of this article about the simple use of Vue's bus. For more relevant content about the simple use of Vue's bus, 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:
  • How much do you know about custom events in Vue components
  • Vue component learning scoped detailed explanation
  • Vue publish-subscribe model implementation process diagram
  • Detailed explanation of the practical application of the publish-subscribe model in Vue
  • Detailed explanation of Vue bus mechanism (bus) knowledge points
  • Detailed explanation of event bus and message publishing and subscription of Vue components

<<:  How to Install Xrdp Server (Remote Desktop) on Ubuntu 20.04

>>:  MySql COALESCE function usage code example

Recommend

Convert XHTML CSS pages to printer pages

<br />In the past, creating a printer-friend...

How InnoDB cleverly implements transaction isolation levels

Preface In the previous article Detailed Explanat...

Solution to data duplication when using limit+order by in MySql paging

Table of contents summary Problem Description Ana...

How to query duplicate data in mysql table

INSERT INTO hk_test(username, passwd) VALUES (...

Solve the problem of specifying udp port number in docker

When Docker starts a container, it specifies the ...

The new version of Chrome browser settings allows cross-domain implementation

Preface Currently, the front-end solves cross-dom...

Summary of Docker Consul container service updates and issues found

Table of contents 1. Container service update and...

More popular and creative dark background web design examples

Dark background style page design is very popular...

jQuery plugin to achieve code rain effect

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

Introduction to CSS3 color value RGBA and gradient color usage

Before CSS3, gradient images could only be used a...

Vue custom components use event modifiers to step on the pit record

Preface Today, when I was using a self-written co...