Vue 中的模塊傳參通常有兩種方式:props 和事件。在實際開發中,我們會根據具體的情況選擇使用其中的一種或兩種方式。
props 是一種父子組件傳參的方式,可以將父組件中的數據傳遞給子組件。具體用法如下:
Vue.component('child', {
// 聲明 props
props: ['msg'],
// 在模板中引用 props
template: '<div>{{ msg }}</div>'
})
Vue.component('parent', {
template: '<child msg="Hello Vue!" />'
})
在上面的代碼中,父組件傳遞了一個 msg 屬性給子組件,子組件可以在模板中使用這個屬性。需要注意的是,在聲明 props 時需要將需要傳遞的屬性以數組的形式傳入。另外,在父組件中傳遞屬性時,需要使用 v-bind 或簡寫 :,具體的語法請參考 Vue 官方文檔。
除了 props,還有一種常用的模塊傳參方式是事件。事件通常用于子組件向父組件傳遞數據或通知父組件發生了某個事件。具體用法如下:
Vue.component('child', {
template: '<button @click="handleClick">Click me!</button>',
methods: {
handleClick() {
// 觸發事件,并傳遞數據
this.$emit('custom-event', 'Hello Vue!')
}
}
})
Vue.component('parent', {
template: '<child @custom-event="handleCustomEvent"></child>',
methods: {
handleCustomEvent(msg) {
// 處理事件傳遞過來的數據
console.log(msg) // "Hello Vue!"
}
}
})
在上面的代碼中,子組件通過 $emit 方法觸發自定義事件,并傳遞了一個參數。在父組件中,使用 @custom-event 的方式監聽自定義事件,并在 handleCustomEvent 方法中處理傳遞過來的參數。需要注意的是,在監聽自定義事件時,需要使用 kebab-case 的方式命名事件(即使用短橫線而不是駝峰式命名)。
總的來說,props 和事件是 Vue 中常用的模塊傳參方式,不同的情況下可以選擇使用其中的一種或兩種方式,具體的選擇要根據實際情況而定。
上一篇curl如何返回json
下一篇vue 模板 不能用