Vue中組件的數(shù)據(jù)共享分析講解
組件之間的關(guān)系
在項(xiàng)目開發(fā)中,組件之間的最常見的關(guān)系分為兩種
- 父子關(guān)系
- 兄弟關(guān)系
父->子共享數(shù)據(jù)
父組件向子組件共享數(shù)據(jù)需要使用自定義屬性。
父子組件之間的數(shù)據(jù)共享
父組件:
<template>
<div id="app">
<h1>app根組件</h1>
<left :msg="message" :user="user"></left>
</div>
</template>
<script>
import left from "./components/left.vue"
export default{
data(){
return {
message:"hello everyone",
user:{
name:"張三",
age:18
}
}
},
components:{
left
}
}
</script>
<style>
#app{
width: 100%;
height: 200px;
background-color: aqua;
}
</style>子組件:
<template>
<div>
<p>msg的值是:{{msg}}</p>
<p >user的值是:{{user}}</p>
<!-- 打開控制臺(tái)vue看點(diǎn)擊后的變化 -->
<!-- 點(diǎn)擊修改終端報(bào)錯(cuò),修改的是復(fù)制了一份的值,跟原來的值無關(guān),也就是父組件沒變化
但不建議這樣用
-->
<button @click="msg='aaa'">修改msg</button>
<!-- 終端報(bào)錯(cuò) 效果同上-->
<button @click="user={sex:'男'}">修改user</button>
<!-- 父組件,子組件都發(fā)生了變化 -->
<button @click="user.name='李四'">修改user里的值</button>
<!-- 以上方法不可取,要保證props是只讀的,要想修改最好轉(zhuǎn)存一份 -->
</div>
</template>
<script>
export default {
props:["msg","user"],
components:{
}
}
</script>
<style scoped>
p{color:red}
/deep/ h5{
color:orange;
}
</style>子->父共享數(shù)據(jù)
子組件向父組件共享數(shù)據(jù)使用自定義事件。
子組件:
<template>
<div>
<!-- <p>msg的值是:{{msg}}</p> -->
<!-- <p>user的值是:{{user}}</p> -->
<h3>{{num}}</h3>
<button @click="add">加一</button>
</div>
</template>
<script>
export default {
data(){
return{
num:0
}
},
methods:{
add(){
// 讓子組件的num值自增加1
this.num+=1
// 把自增的結(jié)果,傳給父組件 自定義屬性名,值
this.$emit("numchange",this.num)
}
},
}
</script>
<style lang="less">
p{color:red}
/deep/ h5{
color:orange;
}
</style>父組件:
<template>
<div id="app">
<h1 >app根組件{{numFromSon}}</h1>
<left @numchange="getnum"></left>
</div>
</template>
<script>
import left from "./components/left.vue"
export default{
data(){
return {
message:"hello everyone",
user: {name: "張三",age: 18},
numFromSon:0
}
},methods:{
// 獲取子組件傳遞過來的數(shù)據(jù)
getnum(val){
this.numFromSon=val
}
},
components:{
left
}
}
</script>
<style>
#app{
width: 100%;
height: 200px;
background-color: aqua;
}
</style>兄弟組件之間的數(shù)據(jù)共享
在vue2.x中,兄弟組件之間數(shù)據(jù)共享的方案是EventBus。之后根組件調(diào)用兩兄弟標(biāo)簽,通過跟組件顯示效果。
EventBus的使用步驟
- 創(chuàng)建eventBus.js模塊,并向外共享一個(gè)Vue的實(shí)例對(duì)象。
- 在數(shù)據(jù)發(fā)送方,調(diào)用bus.$emit(“事件名稱”,要發(fā)送的數(shù)據(jù))方法觸發(fā)自定義事件。
- 在數(shù)據(jù)接收方,調(diào)用bus.$on(“事件名稱”,事件處理函數(shù))方法注冊(cè)一個(gè)自定義事件。
發(fā)送方:
<template>
<div>
<button @click="send">把文字發(fā)送給兄弟組件</button>
</div>
</template>
<script>
import bus from "./eventBus.js"
export default {
data(){
return{
text:"我有一劍,可破世間萬物"
}
},
methods:{
send(){
// 通過eventBus發(fā)送數(shù)據(jù)
bus.$emit("share",this.text)
}
},
}
</script>
<style lang="less">
p{color:red}
/deep/ h5{
color:orange;
}
</style>EventBus:
import Vue from "vue" // 向外共享Vue的實(shí)例對(duì)象 export default new Vue()
接收方:
<template>
<div>
<p>{{textFromLeft}}</p>
</div>
</template>
<script>
// 導(dǎo)入eventBus模塊
import bus from "./eventBus.js"
export default {
data(){
return{
textFromLeft:""
}
},
created(){
// 為bus綁定自定義事件
bus.$on("share",(val)=>{
this. textFromLeft=val
})
},
components:{
}
}
</script>
<style>
div{
width: 50%;
float: left;
}
h5{
color: blueviolet;
}
</style>>效果:

到此這篇關(guān)于Vue中組件的數(shù)據(jù)共享分析講解的文章就介紹到這了,更多相關(guān)Vue組件數(shù)據(jù)共享內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue中如何動(dòng)態(tài)綁定圖片,vue中通過data返回圖片路徑的方法
下面小編就為大家分享一篇vue中如何動(dòng)態(tài)綁定圖片,vue中通過data返回圖片路徑的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-02-02
vue-router4動(dòng)態(tài)路由刷新404/白屏的解決
本文主要介紹了vue-router4動(dòng)態(tài)路由刷新404/白屏的解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
Vue中的watch是什么以及watch和computed的區(qū)別
這篇文章主要介紹了Vue中的watch是什么以及watch和computed的區(qū)別說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
mpvue微信小程序開發(fā)之實(shí)現(xiàn)一個(gè)彈幕評(píng)論
這篇文章主要介紹了mpvue小程序開發(fā)之 實(shí)現(xiàn)一個(gè)彈幕評(píng)論功能,本文通過實(shí)例講解的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11
vue基于session和github-oauth2實(shí)現(xiàn)登錄注冊(cè)驗(yàn)證思路詳解
通過 sessionId 可以在 session 表中獲取用戶的信息,此外,還利用 session 表實(shí)現(xiàn)了GitHub 的 OAuth2 第三方登錄,本文講解前端通過簡(jiǎn)單的方式實(shí)現(xiàn)一個(gè)基本的登錄注冊(cè)驗(yàn)證功能,感興趣的朋友跟隨小編一起看看吧2024-08-08
Vue3使用dataV報(bào)錯(cuò)問題的解決方法
這篇文章主要為大家詳細(xì)介紹了Vue3中使用dataV報(bào)錯(cuò)問題的解決方法,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-11-11
vue實(shí)現(xiàn)給當(dāng)前元素添加樣式,其他元素?zé)o樣式問題
這篇文章主要介紹了vue實(shí)現(xiàn)給當(dāng)前元素添加樣式,其他元素?zé)o樣式問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05

