vue組件間的通信有父--->子、子--->父、非父子之間的通信
雖然我們稍微復雜的項目都用vuex來管理了,但是還是想寫一篇關于有父--->子、子--->父、非父子
之間通信的文章。下面通過代碼來講述
父--->子組件間的通信
父級頁面:
<template>
<div id="app">
<Header :parentMsg='parentMsg' >
</Header>
</div>
</template>
import Header from './components/header'
export default {
name: 'App',
data () {
return {
parentMsg: '你訪問的是父級頁面的數(shù)據(jù)',
}
},
components:{
Header,
}
}
子頁面:
<template>
<div>
<div >{{parentMsg}}</div>
</div>
</template>
export default {
name: 'Header',
props:['parentMsg'], //接收父級頁面?zhèn)鬟^來的數(shù)據(jù)
data(){
return {
parentMsg:''
}
}
}
子--->父組件間的通信
父級頁面:
<template>
<div id="app">
<Header :parentMsg='parentMsg' @tanster='getuser'>
</Header>
<p>
父級頁面接收子頁面的數(shù)據(jù):{{user}}
</p>
</div>
</template>
<script>
import Header from './components/header'
export default {
name: 'App',
data () {
return {
parentMsg: '你訪問的是父級頁面的數(shù)據(jù)',
user:''
}
},
components:{
Header,
},
methods:{
getuser(msg){
this.user=msg //接收子頁面?zhèn)鬟^來的數(shù)據(jù)
}
}
}
</script>
子頁面:
<template>
<div>
<div >{{parentMsg}}</div>
<p>header頁面{{msg}}</p>
<input v-model="msg" @change=getuser()>
</div>
</template>
<script>
export default {
name: 'Header',
props:['parentMsg'],
data(){
return {
msg:''
}
},
methods:{
getuser(){
// 傳給父組件
this.$emit('tanster',this.msg) //傳給父級頁面
},
}
}
</script>
非父子組件頁面間的通信,可以使用EventBus
使用EventBus首先需要新建一個EventBus.js,代碼如下:
import Vue from 'vue'
export default new Vue()
// import Vue from 'vue'
// const EventBus = new Vue()
// export {EventBus}
子頁面1:
<template>
<div>
<input v-model="msg">
<button @click="send()">send</button>
</div>
</template>
<script>
import EventBus from '../assets/js/EventBus'
export default {
name: 'Header',
data(){
return {
msg:''
}
},
methods:{
send(){
EventBus.$emit('sub-msg',this.msg); //向頁面2發(fā)送數(shù)據(jù)
}
}
}
</script>
子頁面2:
<template>
<div>
<p>sub頁面接收header頁面?zhèn)鬟^來的數(shù)據(jù):<span>{{msg}}</span></p>
</div>
</template>
<script>
import EventBus from '../assets/js/EventBus'
export default {
name: 'Sub',
data(){
return {
msg:''
}
},
mounted(){
EventBus.$on('sub-msg',function(msg){
this.msg=msg; //接收頁面1傳過來的數(shù)據(jù)
}.bind(this));
}
}
</script>
以上就是組件間同信的三種方式,還有一種通信就是vuex,vuex在本文就不寫了,之前寫過一篇對vuex
的使用及理解。針對一些數(shù)據(jù)比較難管理的項目來說還是用vuex,方便數(shù)據(jù)的管理。
網(wǎng)頁名稱:vue組件之間的通信
URL網(wǎng)址:http://aaarwkj.com/article38/pdejsp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設計、網(wǎng)站內(nèi)鏈、網(wǎng)站收錄、App設計、商城網(wǎng)站、軟件開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)