Detailed explanation of Vue's self-implementation of dispatch and broadcast (dispatch and broadcast)

Detailed explanation of Vue's self-implementation of dispatch and broadcast (dispatch and broadcast)

Problem to be solved

Mainly for cross-level communication between components

Why do you need to implement dispatch and broadcast yourself?

Because when developing independent components or libraries, it is best not to rely on third-party libraries

Why not use provide and inject?

Because its usage scenario is mainly for sub-components to obtain the status of parent components, an active provision and dependency injection relationship is established between cross-level components.
Then there are two scenarios that it cannot solve well:
The parent component passes data to the child component (supports cross-level);
The child component passes data to the parent component (supports cross-level).

The code is as follows:

emitter.js

function broadcast(componentName, eventName, params) {
 this.$children.forEach(child => {
  const name = child.$options.name;

  if (name === componentName) {
   child.$emit.apply(child, [eventName].concat(params));
  } else {
   // todo If params is an empty array, it will receive undefined
   broadcast.apply(child, [componentName, eventName].concat([params]));
  }
 });
}
export default {
 methods: {
  dispatch(componentName, eventName, params) {
   let parent = this.$parent || this.$root;
   let name = parent.$options.name;

   while (parent && (!name || name !== componentName)) {
    parent = parent.$parent;

    if (parent) {
     name = parent.$options.name;
    }
   }
   if (parent) {
    parent.$emit.apply(parent, [eventName].concat(params));
   }
  },
  broadcast(componentName, eventName, params) {
   broadcast.call(this, componentName, eventName, params);
  }
 }
};

parent.vue

<template>
 <div>
  <h1>I am the parent component</h1>
  <button @click="handleClick">Trigger event</button> <child />
 </div>
</template>
<script>
import Emitter from "@/mixins/emitter.js";
import Child from "./child";
export default {
 name: "componentA",
 mixins: [Emitter],
 created() {
  this.$on("child-to-p", this.handleChild);
 },
 methods: {
  handleClick() {
   this.broadcast("componentB", "on-message", "Hello Vue.js");
  },
  handleChild(val) {
   alert(val);
  }
 },
 components:
  Child
 }
};
</script>

child.vue

<template>
 <div>I am a child component</div>
</template>
<script>
import Emitter from "@/mixins/emitter.js";
export default {
 name: "componentB",
 mixins: [Emitter],
 created() {
  this.$on("on-message", this.showMessage);
  this.dispatch("componentA", "child-to-p", "hello parent");
 },
 methods: {
  showMessage(text) {
   window.alert(text);
  }
 }
};
</script>

In this way, cross-level component custom communication can be achieved. However, one problem should be noted: subscription must precede publishing, that is, on must come before emit.

Parent-child component rendering order, instance creation order

The child component is rendered before the parent component, so when the mounted event of the child component is dispatched, it cannot be heard in the mount in the parent component.
The create of the parent component precedes the child component, so the create in the parent component can be monitored

This is the end of this article about Vue's self-implemented dispatch and broadcast (dispatch and broadcast). For more relevant Vue dispatch and broadcast 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:
  • Vue SPA single-page application first screen optimization practice
  • Vue implementation example of boradcast and dispatch
  • vue-cli single page pre-rendering seo-prerender-spa-plugin operation
  • Usage of store.commit and store.dispatch in vuex
  • Vue SPA first enters the loading animation implementation code
  • Vue realizes the effect of merging columns in data table rowspan
  • Routing caching problems and solutions in Vue SPA applications
  • Solve the problem that Vuex's Dispatch has no effect under Vue+Electron
  • VUE solves the WeChat signature and SPA WeChat invalid signature problem (perfect processing)
  • Detailed explanation of when the action in vuex is completed and how to call dispatch correctly
  • Vue SPA first screen optimization solution

<<:  How to change the root password in MySQL 5.7

>>:  How to implement remote automatic backup of MongoDB in Linux

Recommend

MySQL Failover Notes: Application-Aware Design Detailed Explanation

1. Introduction As we all know, in the applicatio...

Prometheus monitors MySQL using grafana display

Table of contents Prometheus monitors MySQL throu...

Brief analysis of centos 7 mysql-8.0.19-1.el7.x86_64.rpm-bundle.tar

Baidu Cloud Disk: Link: https://pan.baidu.com/s/1...

Docker-compose image release process analysis of springboot project

Introduction The Docker-Compose project is an off...

MySQL 8.0.11 installation and configuration method graphic tutorial

The installation and configuration methods of MyS...

Analysis of MySQL lock mechanism and usage

This article uses examples to illustrate the MySQ...

Detailed explanation of common MySQL operation commands in Linux terminal

Serve: # chkconfig --list List all system service...

Pitfalls based on MySQL default sorting rules

The default varchar type in MySQL is case insensi...

Example code of vue + element ui to realize player function

The display without the effect picture is just em...

Detailed explanation of asynchronous iterators in nodejs

Table of contents Preface What are asynchronous i...

IIS7 IIS8 reverse proxy rule writing, installation and configuration method

Purpose: Treat Station A as the secondary directo...

Overview of the definition of HTC components after IE5.0

Before the release of Microsoft IE 5.0, the bigges...

MySQL slow query pt-query-digest analysis of slow query log

1. Introduction pt-query-digest is a tool for ana...

Detailed explanation of the mysql database LIKE operator in python

The LIKE operator is used in the WHERE clause to ...