preface

It is believed that students who have used VUE in actual projects must be familiar with the communication between parent and child components in VUE. Good data communication methods are adopted in VUE to avoid the troubles caused by component communication. Today, I would like to share with you the communication between vUE father and son components, advantages and disadvantages, and its practical application scenarios

First of all, let’s think with these questions in mind

1. How many parent-child communication methods are there in VUE?

What is the best way for the parent and child components to communicate in VUE?

3 What is the application scenario of each VUE communication mode?

A prop

1. Basic Usage

This is the most common type of parent component communication. We can bind properties and methods to the child component directly in the tag. The properties can be obtained directly from the child component’s prop declaration, and the methods of the parent element can be triggered by this.

Let’s write a simple scenario in which the props and parent components communicate

The parent component

<template>
  <div class="father" >
     <input  v-model="mes"   /> <button @click="send"  >To the child component</button>
     <div>The child component says to me: {{sonMes}}</div>
     <son :fatherMes="sendSonMes" @sonSay="sonSay"   />
  </div>
</template>
<script>
import son from './son'
export default {
   name:'father'.components:{
       son /* Subcomponent */
   },
   data(){
       return {
          mes:' '.sendSonMes:' './* Information from subcomponents */
          sonMes:' '      /* The message sent to the child component */}},methods: {/* Pass to the child component */
      send(){
          this.sendSonMes = this.mes
      },
      /* Accept subcomponent information */ 
      sonSay(value){
          this.sonMes = value
      },
   },
}
</script>

Copy the code

We just need to tag the data fatherMes for the child component and the method sonSay for the child component.

Child components

<template>
    <div class="son" >
        <div>The parent component says to me: {{fatherMes}}</div>
        <input  v-model="mes"   /> <button @click="send"  >Said to the parent component</button>
    </div> 
</template>
<script>
export default {
   name:'son'.props: {fatherMes: {type:String.default:' '}},data(){
       return {
           mes:' '}},methods: {send(){
           this.$emit('sonSay'.this.mes)
       }
   },  
}
</script>>
Copy the code

$emit = this; $emit = this; $emit = this; $emit = this; $emit = this;

Props for react

This is different from the react props. The react component updates from the props update and its own state change. When the react props change, it updates the component by default. In Vue, if we don’t do a dependency collection (template or computed) on the new props passed by the parent component, the component doesn’t touch the update.

The effect

Data formatting

If we want to format the props data, then take the props with computed and format the desired data type.

<div class="son" >
        <div>The parent component says to me: {{computedFatherMes}}</div>
         <input  v-model="mes"   /> <button @click="send"  >Said to the parent component</button>
</div> 
Copy the code
export default {
   name:'son'.props: {fatherMes: {type:String.default:' '}},computed: {computedFatherMes(){
           return this.fatherMes + '๐Ÿ˜„ ๐Ÿ˜„'}}},Copy the code

Data to monitor

When we don’t want to update the view according to the props change, or we don’t want to update the view immediately, we can use watch to listen for the props change from the parent component.

watch:{
    fatherMes(newVaule){
        console.log(  newVaule) 
    }
},
Copy the code

2 advantages

The advantages of passing props data are obvious. It is flexible and simple. You can perform computing properties, data listening, and other processing on props data. The communication between father and son components is flexible and convenient. This could be a father-son floor only.

Three shortcomings

1 props to tamper with

When we use the props of a parent component in a child component, we want to change the props of the parent component. We want to change the props of the parent component as well. We want to change the props of the parent component as well. Can vue props change or not? If props is the basic data type, when we change it, we’ll expose an error. Let’s look at an example.

The parent component

<template>
    <div>
        <div>The parent component</div>
        <son :fData="sonProps"  />
    </div>
</template>
<script>
import son from './sTampering'
export default {
    name:'father'.components:{
      son
    },
    data(){
      return {
          sonProps:' '}}},</script>
Copy the code

Child components

<template>
    <button >Changes the parent component props</button>
</template>

<script>
export default {
    name:'son'.props: {fData: {required:true}},methods: {changFatherProps(){
           this.fData = 'hello ,father'}}}</script>
Copy the code

The following alert is thrown when we click on the button directly.

But when we pass in a reference data type and modify a property under the data.

The parent component

data(){
    return {
        sonProps: {a:1.b:2}}},Copy the code

Child components

changFatherProps(){
   this.fData.a = 'hello,world'
}
Copy the code

No error was reported when the button was clicked.

So we print the sonprops for the parent:

We found that the data of the parent component had been tampered with by the component. If the parent component is a reference type, the child component can modify the props properties of the parent component. If the parent component is a reference type, the child component can modify the props properties of the parent component. This is an awkward situation. If we are designed to modify the parent data at the same time, this is acceptable, but if we do not want any changes to the parent data source, this is a serious logic bug. So that’s one of the props communications risks.

2 cross – layer communication, sibling components communication difficulty

For the parent component – child component – child component this kind of cross-hierarchy communication, obviously needs our prop binding properties and methods layer by layer, if encountered more complex situation, it is difficult to implement.

For communication between sibling components,propsThe communication mode of child component -> parent component -> child component needs to be realized through the parent component as a bridge. If you want to use the parent component as a medium, it will cause the parent component to re-render, and it will cost a lot to realize the communication of brother components.

4 Application Scenarios

The props function can be used in a simple way. It’s normal for a parent component to communicate with its parent component, or a sibling component with less complex relationships.

2 this. $XXX

This is a violent way to get a vue instance directly from the data below this, because what we call a component is ultimately an object that holds information about the component, and components are associated with this.$children and this.$parent Pointers. Since there is only one root component in the project, it is theoretically possible to use this.$children this.$parent to access any component on the page, but in practice it is a very difficult problem to exactly match the target component.

1. Basic Usage

The parent component

<template>
  <div class="father" >
     <input  v-model="mes"   /> <button @click="send"  >To the child component</button>
     <son2 v-if="false" />
     <div>The child component says to me: {{sonMes}}</div>
     <son />
  </div>
</template>
<script>
import son from './son'
import son2 from './son2'
export default {
   name:'father'.components:{
       son ,/* Subcomponent */
       son2
   },
   data(){
       return {
          mes:' '.sendSonMes:' './* Information from subcomponents */
          sonMes:' '      /* The message sent to the child component */}},methods: {/* Pass to the child component */
      send(){
          /* Since the son component is the first valid component, go to the component whose subscript is 0 */
          const currentChildren = this.$children[0]
          currentChildren.accept(this.mes)
      },
      /* Receive subcomponent information */
      accept(value){
         this.sonMes = value
      }
      
   },
}
</script>
Copy the code

Child components

<template>
    <div class="son" >
        <div>The parent component says to me: {{fatherMes}}</div>
        <input  v-model="mes"   /> <button @click="send"  >Said to the parent component</button>
    </div> 
</template>
<script>
export default {
   name:'son'.data(){
       return {
           mes:' '.fatherMes:' '}},methods: {/* Accept parent content */
       accept(value){
         this.fatherMes = value
       },
       /* Send a message to the parent */
       send(){
           this.$parent.accept(this.mes)
       },
   },
}
</script>

Copy the code

The effect

This.$parent, this.$children: functions, functions, functions, functions, functions, functions It may seem convenient to implement communication between components, but in practice it has great disadvantages, and vUE itself does not advocate this kind of communication. And there are a lot of risks to this type of communication, which we’ll explain later.

2 advantages

This.$children,this.$parent this.$refs this communication mode, more simple direct access to vUE instance, vUE instance data and methods directly access or reference.

Three shortcomings

1 $this. Children are not controllable, there is a certain risk

In the example above, if we make minor changes to the parent component, the error will be reported directly.

Before the

 <son2 v-if="false" />
Copy the code

to

<son2 v-if="true" />
Copy the code

This.$children[0] = son2 v-if = true; son2 v-if = true; This.$children is not recommended for v-if dynamic control components that are hidden. Instead, we can use ref to retrieve instances of the corresponding child components.

The above change

<son ref="son" />
Copy the code

Then get:

const currentChildren = this.$refs.son
Copy the code

The problem was fundamentally solved.

2 is not conducive to componentization

Direct access component instance this way, to a certain extent, hampered the development of modular, modular development process, the method is provided to the outside, the method is for internal use, in the absence of in advance to discuss, and component state opaque cases, everything is unknown, so different developers access to the method, the component risk, Whether there is some internal coupling between the provided component methods and the properties. The idea of component development is not to make certain internal changes from the outside of the component, but to notify the method events bound to the outside. Conversely, if the child component is inside, it actively passes some information to the parent component, and it is not sure whether the parent component exists.

3 sibling components Deeply nested components are difficult to communicate

And props, if brother direct component of communication, through the parent component as a bridge of communication between, and deep communication components, although do not need to step by step as props communications binding, but have a bit, to gradually to the upper or the lower target instance, how to accurately obtain this is a very headache problem, And every time you go deeper, the risks and uncertainties grow.

4 Application Scenarios

Direct instance communication fits into a known, immobilised page structure. This communication requires parent and child components to be highly transparent and to know which method attributes they have and what they are used for. Therefore, this approach is more suitable for page components than for some third-party component libraries or common components.

Three dojo.provide inject

If we say provide and inject in Vue, I will first think of react context. The two functions are very similar to each other to some extent. Provide exposes methods, properties, or instances of itself on parent components. The slot component, even the slot component of the descendant component, is imported by Inject. Provide for your own use. Classic examples of provide and inject are el-form and El-form-item in element-UI

Let’s imagine a scenario with a question

<el-form  label-width="80px" :model="formData">
  <el-form-item label="Name">
    <el-input v-model="formData.name"></el-input>
  </el-form-item>
  <el-form-item label="Age">
    <el-input v-model="formData.age"></el-input>
  </el-form-item>
</el-form>
Copy the code

We can see that el-Form and El-Form-item do not need to establish any communication operations, so how are el-Form and El-Form-item related and share state? We continue to look with questions.

1. Basic Usage

The ordinary way

Let’s use the case of parent -> child -> grandson

The parent component

<template>
  <div class="father" >
     <div>The child component says to me: {{sonMes}}</div>
     <div>{{grandSonMes}}</div>
     <son />
  </div>
</template>
<script>
import son from './son'
export default {
   name:'father'.components:{
       son /* Subcomponent */
   },
   provide(){
       return {
           /* Expose yourself to the descendant component by declaring the same name as the child component imported */
           father:this}},data(){
       return {
          grandSonMes:' './* Information from subcomponents */
          sonMes:' '      /* The message sent to the child component */}},methods: {/* Accept sun component information */
      grandSonSay(value){
          this.grandSonMes = value
      },
      /* Accept subcomponent information */ 
      sonSay(value){
          this.sonMes = value
      },
   },
}
</script>

Copy the code

Here we are exposing ourselves by providing. โš ๏ธโš ๏ธโš ๏ธ The specified name must be the same as the name imported by the child component

Child components

<template>
    <div class="son" >
        <input  v-model="mes"   /> <button @click="send"  >Said to the parent component</button>
        <grandSon />
    </div> 
</template>

<script>
import  grandSon from './grandSon'
export default {
    /* Subcomponent */
   name:'son'.components:{
       grandSon /* Sun component */
   },
   data(){
       return {
           mes:' '}},/* Introduce the parent component */
   inject: ['father'].methods: {send(){
           this.father.sonSay(this.mes)
       }
   },
    
}
</script>
Copy the code

The child component imports the instance of the parent component through inject, and then obtains the parent component directly through this.father, and calls the sonSay method below.

Sun components

<template>
   <div class="grandSon" >
        <input  v-model="mes"  /> <button @click="send"  >Said to the grandpa component</button>
    </div> 
</template>

<script>
export default {
    /* Sun component */
   name:'grandSon'./* Introduce the grandfather component */
   inject: ['father'].data(){
       return {
           mes:' '}},methods: {send(){
           this.father.grandSonSay( this.mes )
       }
   }
}
</script>
Copy the code

The grandson component does not have how to operate, the method introduced is the same as the child component.

The effect

2 Slot Mode

Provide, inject can also be applied to slots, we changed the parent component slightly.

The parent component

<template>
  <div class="father" >
     <div>The child component says to me: {{sonMes}}</div>
     <div>{{grandSonMes}}</div>
     <son >
         <grandSon/>
     </son>
  </div>
</template>
<script>
import son from './slotSon'

import grandSon from './grandSon' 
export default {
   name:'father'.components:{
       son, /* Subcomponent */
       grandSon /* Sun component */
   },
   provide(){
       return {
           /* Expose yourself to descendant components */
           father:this}},data(){
       return {
          grandSonMes:' './* Information from subcomponents */
          sonMes:' '      /* The message sent to the child component */}},methods: {/* Accept sun component information */
      grandSonSay(value){
          this.grandSonMes = value
      },
      /* Accept subcomponent information */ 
      sonSay(value){
          this.sonMes = value
      },
   },
}
</script>
Copy the code

Child components

<template>
    <div class="son" >
        <input  v-model="mes"   /> <button @click="send"  >Said to the parent component</button>
        <slot />
    </div> 
</template>
Copy the code

The same communication effect is achieved. In the actual slot mode, all components are registered with the parent component, and the grandchild component is bound to the children component. Similar to the situation above.

Provied other uses

provideNot only can you expose the entire parent, but you can also expose only a portion (some of the parent’s properties or methods) as needed. In the example above, only the parent’s methods are used in the descendant, so we can provide only two communication methods. But the thing to notice here is that if we provide methods out, if we have operations inside of methodsthisBehavior, which requires bindingthis

The parent component

   provide(){
       return {
           /* Expose the communication method to the descendant (note the binding to this) */
           grandSonSay:this.grandSonSay.bind(this),
           sonSay:this.sonSay.bind(this)}},methods: {/* Accept sun component information */
      grandSonSay(value){
          this.grandSonMes = value
      },
      /* Accept subcomponent information */ 
      sonSay(value){
          this.sonMes = value
      },
   },

Copy the code

Child components

/* Introduce the parent component method */
   inject: ['sonSay'].methods: {send(){
           this.sonSay(this.mes)
       }
   },
Copy the code

2 advantages

1 Component communication is not affected by the sub-component hierarchy

Provide inject is very similar to react. Context in that provide is equivalent to context. Provider and inject is equivalent to context. Consumer, so that communication between parent components is not affected by the component’s deeper descendants.

2 Applies to slots, nested slots

Provide inject makes it easy to communicate parent-child components nested with slots. This is why el-Form and El-Form-Item are able to coordinate the state of the form in the same way. El-form provides this itself in the Element source code.

Three shortcomings

1 not suitable for brother communication

Provide – Inject coordination is to retrieve states, methods, properties, etc provided by parent components. The flow is always from parent to child. Provide – provide contents cannot be accessed by sibling components, so communication between sibling components cannot be accomplished in this way.

2 The parent component cannot communicate actively

Provid-inject is more like a father earning money to spend on his son. The son can get the conditions provided from his father, but the father cannot demand anything from his son. As the analogy goes, the parent component knows nothing about the state of the child component. You cannot actively initiate communication to a child component.

4 Application Scenarios

The provide- Inject communication mode is more suitable for deep and complex parent-child communication. The descendant component can share the state of the parent component, and it is suitable for the el-form el-form-Item slot type scenario.

Four vuex

Vuex is the best solution for dealing with complex component communication in VUE, after all, vUE and VUex are from the same womb. And the vuex bottom is also implemented with vue. I believe many students are no strangers to VUEX. Let’s start with vuex.

1 Basic Usage

Vuex file

import Vuex from 'vuex'
import Vue from 'vue'

Vue.use(Vuex)

export default new Vuex.Store({
    state: {fatherMes:' '.sonMes:' '.fatherMesAsync:' '
    },
    mutations: {sayFaher(state,value){
           state.fatherMes = value
       },
       saySon(state,value){
           state.sonMes = value
       },
       sayAsyncFather(state,value){
           state.fatherMesAsync = value
       }
    },
    actions: {asyncSayFather({ commit },payload){
           return new Promise((resolve) = >{
               setTimeout(() = >{
                   resolve(payload)
               },2000)
           }).then(res= >{
               commit('sayAsyncFather',res)
           })
       }
    }
})
Copy the code

In the Store file, we state that three mutations communicate saySon to the parent component, and the parent to the child component, respectively, The synchronous method sayFaher and the asynchronous method sayAsyncFather simulate an asynchronous task asyncSayFather that is executed after three seconds.

main.js

import store from './components/vuex/store'

new Vue({
  render: h= > h(App),
  store
}).$mount('#app')
Copy the code

The main js into the store

The parent component

<template>
  <div class="father" >
     <input  v-model="mes"   /> <button @click="send"  >Sync: said to a child component</button><br/>
      <input  v-model="asyncMes"   /> <button @click="asyncSend" >Asynchronous: said to a child component</button><br/>
     <div>The child component says to me: {{sonMes}}</div>
     <son />
  </div>
</template>
<script>
import son from './son'
export default {
   /* Parent component */
   name:'father'.components:{
       son ,/* Subcomponent */
   },
   data(){
       return {
          mes:' '.asyncMes:' '}},computed: {sonMes(){
           return this.$store.state.sonMes
       }
   },
   mounted(){
       console.log(this.$store)
   },
   methods: {Mutations are triggered, transferring data to the subcomponent */
      send(){
        this.$store.commit('sayFaher'.this.mes)
      },
      /* Trigger actions to pass data to the child component */
      asyncSend(){
         this.$store.dispatch('asyncSayFather'.this.asyncMes) 
      }
   },
}
</script>
Copy the code

Each parent triggers synchronous asynchronous methods to send information to the child component. Accept state in VUEX with computed.

Child components

<template>
    <div class="son" >
        <div>The parent component says to me: {{fatherMes}}</div>
        <div>The parent component says to me (asynchronous) : {{fatherMesAsync}}</div>
        <input  v-model="mes"   /> <button @click="send"  >Said to the parent component</button>
    </div> 
</template>
<script>
export default {
   name:'son'.data(){
       return {
           mes:' ',}},computed: {/* Accept the parent synchronization message */
       fatherMes(){
           return this.$store.state.fatherMes
       },
       /* Accept the parent asynchronous message */
       fatherMesAsync(){
           return this.$store.state.fatherMesAsync
       }
   },
   methods: {/* Send a message to the parent */
       send(){
           this.$store.commit('saySon'.this.mes)
       },
   },
    
}
</script>
Copy the code

The child component’s methods are the same as the parent component’s.

The effect

2 advantages

1 Fundamentally solve communication problems of complex components

To some extent, VUEX fundamentally solves the complex communication situation of vUE components. We no longer care about the communication problem of two unrelated components.

2 Supports asynchronous component communication

Actions in VUex allow us to do some asynchronous operations, and then pass the data to the mutation through the COMMIT. The reason why actions can be asynchronous is that promise.resolve can get the completion status of the asynchronous task.

Three shortcomings

1 the process is slightly more complex

Vuex communication mode is more complex than other modes, and if different modules, need to establish independent modules.

4 Application Scenarios

In the actual development scenario, there is no such simple communication as demo project. The appearance of VUEX is to solve these complicated communication scenarios of components. For medium to large projects, VUEX is a good solution for state management and data communication.

5 EventBus 1 EventBus

EventBus event bus, EventBus all events unified scheduling, a unified management event center, a component binding event, another component to trigger events, all the components of communication will no longer receive the limitation of father and son components, the page needs data, binding event, and then the corresponding event is triggered by the data provider to provide the data, This communication scenario applies not only to VUE, but also to React.

$EMIT = this.$on = this.$on = this.$on = this. Let’s focus on this process.

1. Basic Usage

EventBus

export default class EventBus {
    es = {}
     /* Bind events */ 
    on(eventName, cb) {
        if (!this.es[eventName]) {
            this.es[eventName] = []
        }
        this.es[eventName].push({
            cb
        })
    }
    /* Triggers events */
    emit(eventName, ... params) {
        const listeners = this.es[eventName] || []
        let l = listeners.length

        for (let i = 0; i < l; i++) {
            const { cb } = listeners[i]
            cb.apply(this, params)
        }
    }
}

export default new EventBus()
Copy the code

This is a simple event bus with two methods: on and emit.

The parent component

<template>
  <div class="father" >
     <input  v-model="mes"   /> <button @click="send"  >To the child component</button>
     <div>The child component says to me: {{sonMes}}</div>
     <son />
     <brotherSon />
  </div>
</template>
<script>
import son from './son'
import brotherSon from './brother'
import EventBus from './eventBus'
export default {
   name:'father'.components:{
       son ,/* Subcomponent */
       brotherSon, /* Subcomponent */
   },
   data(){
       return {
          mes:' '.sonMes:' '/* The message sent to the child component */}},mounted(){
      /* Bind events */
      EventBus.on('sonSay'.this.sonSay)
   },
   methods: {/* Pass to the child component */
      send(){
          EventBus.emit('fatherSay'.this.mes)
      },
      /* Accept subcomponent information */ 
      sonSay(value){
          this.sonMes = value
      },
   },
}
</script>
Copy the code

We supply it to the child component at initialization by binding the sonSay method to the on method of EventBus. When passing information to the child component, the emit triggers the binding method of the child component, realizing the parent-child communication. Next, let’s look at the instant components.

Child components

<template>
    <div class="son" >
        <div>The parent component says to me: {{fatherMes}}</div>
        <input  v-model="mes"   /> <button @click="send"  >Said to the parent component</button>
        <div>
            <input  v-model="brotherMes"   /> <button @click="sendBrother"  >Say to the brother component</button>
        </div>
    </div> 
</template>
<script>
import EventBus from './eventBus' 
export default {
   name:'son'.data(){
       return {
           mes:' '.brotherMes:' '.fatherMes:' '}},mounted(){
       /* Bind events */
       EventBus.on('fatherSay'.this.fatherSay)
   },
   methods: {/* Pass information to the parent component */
       send(){
          EventBus.emit('sonSay'.this.mes)
       },
       /* Pass messages to sibling components */
       sendBrother(){
          EventBus.emit('brotherSay'.this.brotherMes)
       },
       /* The parent component says to me */
       fatherSay(value){
          this.fatherMes = value
       }
   },
    
}
</script>
Copy the code

Similar to the logic of the parent component, the method that needs to receive data is bound to an EventBus and is sent externally by triggering the EventBus method. We also simulated communication between brothers. We build a sibling component.

<template>
  <div class="son" >{{brotherMes}}</div>
</template>

<script>

import EventBus from './eventBus'
export default {
   / * * /
   name:'brother'.data(){
       return {
          brotherMes:' '}},mounted(){
       /* Bind events to sibling components */
       EventBus.on('brotherSay'.this.brotherSay)
   },
   methods: {brotherSay(value){
           this.brotherMes = value 
       }
   }

}
</script>

Copy the code

As we can see, there is no difference between sibling component processing logic and father-son logic.

The effect

2 advantages

Simple and flexible, father and son communication is not restricted.

The communication mode of eventBus is simpler than the previous ones, and is not affected by the component level. It can realize the communication between any two components. When data is needed, it is bound through on. When data is passed, it emits.

2 Communication mode is not affected by the framework

As for the communication mode of eventBus, not only VUE can use this communication mode, react and small programs can use this communication mode, and the author feels that this communication mode is more suitable for small program communication. As for why I will tell you one by one later.

4 faults

1 difficult maintenance, easy to cause chain problems

If we use the event bus communication mode, because all events are highly centralized, unified management, if there is a link error, it will cause a whole body disaster. And later maintenance is also very difficult.

2 Command specification that requires caution

The actual application scenario is much more complicated than the demo scenario. In the actual scenario, there will be countless pairs of parent and child components, and countless pairs of brother components. We cannot call every event with the same name, so the eventBus binding event name must have strict specifications.

3. It is not conducive to componentized development

EventBus communication is not an efficient way to componentization development. Consider a scenario where there are multiple common components on a page and we only need to pass data to one of them, but each common component is bound with a method for receiving the data. How do we get the data to the desired component?

4 Application Scenarios

Realize the bus is more suitable for this way, WeChat small program, and based on the vue build a small program, as to why, because we all know that small program with double thread model (rendering + logic layer) (as shown in the figure below), rendering layer effect WXML rendering is a small program to our line of sight, and the logic layer is we write code logic, on the performance, We need to realize that the wasted performance at the rendering level is far greater than the performance overhead at the logical level. If we use the props method in our appletops, the properties are bound to the appletops tag, so we have to re-render the view layer. If the page structure is complex, it may cause lag, so we can bypass the rendering layer through eventBus, and directly push the data through the logical layer, saving the performance overhead.

Six event bus two new Vue

New Vue is similar to eventBus. The difference is that Vue instance is used as eventBus center. In addition to using $on,$emit, we can also use data,watch and other methods under Vue. As a data communication bridge between different modules, new Vue is more efficient and suitable for Vue project scenarios than the above EventBus method. Let’s move on.

1 Basic Usage

VueBus

import Vue from 'vue'

export default new Vue()
Copy the code

The parent component

<template>
  <div class="father" >
     <input  v-model="mes"   /> <button @click="send"  >To the child component</button>
     <div>The child component says to me: {{sonMes}}</div>
     <son />
  </div>
</template>
<script>
import son from './son'
import VueBus from './vueBus'
export default {
   /* Parent component */ 
   name:'father'.components:{
       son ,/* Subcomponent */
   },
   data(){
       return {
          mes:' '.sonMes:' ' /* The message sent to the child component */}},created(){
       /* Binding properties */
       VueBus._data.mes = 'hello,world'
   },
   mounted(){
      /* Bind events */
      VueBus.$on('sonSay'.this.sonSay)
   },
   methods: {/* Pass to the child component */
      send(){
         VueBus.$emit('fatherSay'.this.mes)
      },
      /* Accept subcomponent information */ 
      sonSay(value){
          this.sonMes = value
      },
   },
}
</script>
Copy the code

We bind the method that accepts data with $on, and initialize it with the data bound under vue_data.

Child components

<template>
    <div class="son" >
        <div>The parent component says to me: {{fatherMes}}</div>
        <input  v-model="mes"   /> <button @click="send"  >Said to the parent component</button><br/>
        <button @click="getFatherMes" >To get the data</button>
    </div> 
</template>

<script>
import VueBus from './vueBus' 
export default {
   name:'son'.data(){
       return {
           mes:' '.brotherMes:' '.fatherMes:' '}},mounted(){
       /* Bind events */
       VueBus.$on('fatherSay'.this.fatherSay)
   },
   methods: {/* Pass information to the parent component */
       send(){
          VueBus.$emit('sonSay'.this.mes)
       },
       /* The parent component says to me */
       fatherSay(value){
          this.fatherMes = value
       },
       /* Get the data stored in vue by the parent component */
       getFatherMes(){
           console.log( VueBus._data.mes )
       }
   },

    
}
</script>
Copy the code

As with eventBus, we can also directly get the content passed by the parent through _data data.

The effect

2 advantages

1 Simple and flexible, communication between any components.

Like the above eventBus communication method, this communication method is flexible and can be easily implemented between any component.

2 In addition to communication can also be usedwatch , computedMethods such as

If we are using vUE as a medium of communication, then using only $Emit and $ON is really overkill. Now that we have a vUE instance, we can easily use vUE’s $Watch computed and other features.

Three shortcomings

Basically, all the disadvantages of EventBus exist in vUE.

4 Application Scenarios

In small and medium-sized projects that do not consider using VUEX, we can consider using vUE event bus as a communication mode. When using this mode, we must pay attention to the namespace and do not repeat the binding of event names. Separate service modules to avoid subsequent maintenance difficulties.

Write in the back

In writing the VUE project, we need to make a comprehensive evaluation of the specific business scenario, project size and other factors to use the specific communication mode. This article introduces the advantages and disadvantages of VUE communication, which can provide a reference for practical work.

I have been looking at vue2.0 and VUe3.0 source code in my spare time, 3.0 source code out of a few articles, will continue to update, interested students can directly click to read

Vue3.0 Responsive Principle (super detailed)

Comprehensive analysis of vue3.0 Diff algorithm

Vue3.0 Watch and Computed Source parsing (Example illustration)

At the end of the day, if you think it’s ok, you can like it and follow it, and continue to share technical articles.

Official Account: front-end Sharing

Thanks for watching ๐Ÿ™๐Ÿ™๐Ÿ™ ~ ~ ~