Detailed explanation of the use of bus in Vue

Detailed explanation of the use of bus in Vue

Vue bus mechanism (bus)

In addition to using vuex, communication between non-parent-child components in vue can also be done through the bus, and the two are applicable to different scenarios.

The bus is suitable for small projects and projects where data is used by fewer components. It is not suitable for medium and large projects where data is used among many components. Bus is actually a publish-subscribe model. It uses Vue's custom event mechanism to publish an event through $emit at the triggering location, and listens to the event through $on on the page that needs to be listened to.

Vuex is suitable for medium and large projects and situations where data is shared among multiple components.

Use of component communication bus

Create bus.js under the utils file

// utils - bus.js
import Vue from 'vue'
const bus = new Vue()
export default bus

1. Passing Values

Send Message

import bus from '@/utils/bus'

The first parameter is the flag variable, and the second parameter is the communication value.

us.$emit('message', 'hello');

Receiving information

import bus from '@/utils/bus'

The first parameter is the flag variable, and the e in the second parameter is the communication value.

bus.$on('message', (e) => {
 console.log(e)
})

2. Calling method

One component (A) calls a method of another component (B)

Methods of component B

import bus from '@/utils/bus'
mounted () { 
 bus.$on('testA', this.testA) 
},
testA () {
 console.log('Called by component A')
}

A component call

import bus from '@/utils/bus'
mounted () {
 bus.$emit('testA')
}

This is the end of this article about the use of bus in Vue. For more relevant content on the use of vue bus, please search for previous articles on 123WORDPRESS.COM 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 uses eventBus to realize communication between peer components
  • A very detailed summary of communication between Vue components
  • Sample code for implementing sibling component communication using eventBus in vue2.0s
  • Eight ways of component communication in Vue (worth collecting!)
  • The difference and usage of Vue2 and Vue3 brother component communication bus

<<:  Introduction to version management tool Rational ClearCase

>>:  Install docker offline by downloading rpm and related dependencies using yum

Recommend

How to solve the problem that Seata cannot use MySQL 8 version

Possible reasons: The main reason why Seata does ...

Install nvidia graphics driver under Ubuntu (simple installation method)

Install the nvidia graphics card driver under Ubu...

Implementation steps of mysql master-slave replication

Table of contents mysql master-slave replication ...

Draw an iPhone based on CSS3

Result:Implementation Code html <div class=...

Detailed explanation of two points to note in vue3: setup

Table of contents In vue2 In vue3 Notes on setup ...

Solution to forgetting MySQL root password in MACOS

MySQL is a relational database management system ...

Node uses async_hooks module for request tracking

The async_hooks module is an experimental API off...

Introduction to the use of MySQL pt-slave-restart tool

Table of contents When setting up a MySQL master-...

Detailed explanation of using Docker to build externally accessible MySQL

Install MySQL 8.0 docker run -p 63306:3306 -e MYS...

Analyze the usage and principles of Vue's provide and inject

First, let's talk about why we use provide/in...

Several methods of implementing two fixed columns and one adaptive column in CSS

This article introduces several methods of implem...