Vue.component('button-counter', {
template: '<button v-on:click="increment()">{{ counter }}</button>',
data: function () {
return {
counter: 0
}
},
methods: {
increment: function () {
this.counter += 1
}
},
})
例如上面的元件,我希望 v-on監聽的事件是 父元件傳遞過來的,而不是在這裡寫死為click,我該怎麼寫?
我當然知道使用props傳遞,我想知道v-on後面該怎麼寫。如果直接寫propname的話vue會認為要監聽的事件是propname,而不是具體的事件。
PHP中文网2017-06-12 09:34:45
題主的需求比較特殊,如果是這樣的話可能只能用render
代替template
了:
<p id="app">
<button-counter :event="'click'">abc</button-counter>
</p>
const counter = Vue.component('button-counter', {
render(createElement) {
return createElement(
'button', {
on: {
[this.event]: this.increment,
},
},
`${this.counter}`,
)
},
data() {
return {
counter: 0,
}
},
props: {
event: String
},
methods: {
increment() {
this.counter += 1
},
},
})
new Vue({
el: '#app',
components: {
'button-counter': counter,
},
})