Vue父子組件通訊方式及實(shí)現(xiàn)方法
Vue父子組件通訊方式及實(shí)現(xiàn)
1. props和$emit
父組件通過props向子組件傳遞數(shù)據(jù),子組件通過$emit觸發(fā)父組件定義的事件來傳遞數(shù)據(jù)。
父組件:
<template>
<div>
<child-component :message="message" @update-message="updateMessage"></child-component>
</div>
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
name: 'ParentComponent',
components: {
ChildComponent
},
data() {
return {
message: 'Hello World!'
}
},
methods: {
updateMessage(newMessage) {
this.message = newMessage;
}
}
}
</script>子組件:
<template>
<div>
<p>{{ message }}</p>
<button @click="updateMessage">Update Message</button>
</div>
</template>
<script>
export default {
name: 'ChildComponent',
props: ['message'],
methods: {
updateMessage() {
this.$emit('update-message', 'New Message');
}
}
}
</script>2. $parent和$children
父組件可以通過$children屬性獲取到所有子組件的實(shí)例,并通過$parent屬性獲取到自己的父組件實(shí)例。
父組件:
<template>
<div>
<child-component></child-component>
</div>
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
name: 'ParentComponent',
components: {
ChildComponent
},
methods: {
updateMessage(newMessage) {
this.message = newMessage;
}
}
}
</script>子組件:
<template>
<div>
<p>{{ message }}</p>
<button @click="updateMessage">Update Message</button>
</div>
</template>
<script>
export default {
name: 'ChildComponent',
data() {
return {
message: 'Hello World!'
}
},
methods: {
updateMessage() {
this.$parent.updateMessage('New Message');
}
}
}
</script>3. $refs
父組件可以通過ref屬性給子組件設(shè)置一個(gè)引用,然后通過$refs獲取到子組件的實(shí)例,從而調(diào)用子組件的方法或者訪問子組件的屬性。
父組件:
<template>
<div>
<child-component ref="child"></child-component>
</div>
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
name: 'ParentComponent',
components: {
ChildComponent
},
methods: {
updateMessage() {
this.$refs.child.updateMessage('New Message');
}
}
}
</script>子組件:
<template>
<div>
<p>{{ message }}</p>
<button @click="updateMessage">Update Message</button>
</div>
</template>
<script>
export default {
name: 'ChildComponent',
data() {
return {
message: 'Hello World!'
}
},
methods: {
updateMessage(newMessage) {
this.message = newMessage;
}
}
}
</script>到此這篇關(guān)于Vue父子組件通訊方式及實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)Vue父子組件通訊內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
el-tab設(shè)置默認(rèn)激活的標(biāo)簽頁實(shí)現(xiàn)步驟
這篇文章主要給大家介紹了關(guān)于el-tab設(shè)置默認(rèn)激活的標(biāo)簽頁實(shí)現(xiàn)步驟,文中通過代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09
Vue 中v-model的完整用法及v-model的實(shí)現(xiàn)原理解析
這篇文章詳細(xì)介紹了Vue.js中的v-model指令的使用,包括基本用法、原理、結(jié)合不同類型的表單元素(如radio、checkbox、select)以及使用修飾符(如lazy、number、trim)等,感興趣的朋友一起看看吧2025-02-02
vue和iview實(shí)現(xiàn)Scroll 數(shù)據(jù)無限滾動功能
今天小編就為大家分享一篇vue和iview實(shí)現(xiàn)Scroll 數(shù)據(jù)無限滾動功能,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
vue-quill-editor+plupload富文本編輯器實(shí)例詳解
這篇文章主要介紹了vue-quill-editor+plupload富文本編輯器實(shí)例詳解,需要的朋友可以參考下2018-10-10
Vue實(shí)現(xiàn)購物小球拋物線的方法實(shí)例
這篇文章主要給大家介紹了Vue實(shí)現(xiàn)購物小球拋物線的方法實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Vue實(shí)現(xiàn)將數(shù)據(jù)庫中帶html標(biāo)簽的內(nèi)容輸出(原始HTML(Raw HTML))
今天小編就為大家分享一篇Vue實(shí)現(xiàn)將數(shù)據(jù)庫中帶html標(biāo)簽的內(nèi)容輸出(原始HTML(Raw HTML)),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10

