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,props
The 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
provide
Not 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 methodsthis
Behavior, 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
, computed
Methods 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 ๐๐๐ ~ ~ ~