當我們在Vue中使用組件時,會經常遇到父子組件的情況。父子組件可以通過屬性和事件進行數據交互,并且可以進行渲染嵌套,實現復雜的頁面組合效果。
在Vue中,父子組件的渲染是非常簡單的。首先我們需要注冊組件,在注冊時可以指定組件名稱和模板。接下來可以直接在模板中嵌套組件,不需要進行任何額外的操作,Vue會自動進行父子組件渲染。
// 父組件
Vue.component('parent-component', {
template: '<div><child-component :message="message" @foo="handleFoo"></child-component></div>',
data() {
return {
message: 'Hello from parent'
}
},
methods: {
handleFoo() {
console.log('foo event triggered from child component');
}
}
});
// 子組件
Vue.component('child-component', {
props: ['message'],
template: '<div><p>{{ message }}</p></div>',
mounted() {
this.$emit('foo');
}
});
// 實例化Vue對象
new Vue({
el: '#app'
});
在上面的代碼中,我們創建了一個父組件和一個子組件。父組件中使用了子組件,并且將變量message傳遞給了子組件。在子組件中,通過props接收了父組件傳遞過來的message,并且將它渲染到了模板中的p標簽中。此外,在子組件的mounted鉤子函數中,我們還通過$emit方法觸發了一個名為foo的事件,并且在父組件中定義了一個handleFoo方法進行事件處理。
父子組件的數據交互是非常靈活的。除了使用props和$emit方法之外,Vue還提供了很多其他的交互方式,比如v-slot、provide/inject等方法。通過這些交互方式,父子組件可以在應用中共同發揮作用,實現復雜的功能。
上一篇jquery.js有多大
下一篇vue父子通信案例