触发自定义函数,向父组件传递数据
效果:举例:向一个输入框中输入数据,下面显示输入框中的内容
下面展示一些 内联代码片
。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<script src="vue.js"></script>
<body>
<p id="counter-event-example">
<p>{{ total }}</p >
<button-counter v-on:increment1="incrementTotal1"></button-counter>
<button-counter v-on:increment2="incrementTotal2"></button-counter>
</p >
</body>
<script>
Vue.component('button-counter', {
template: '<button v-on:click="increment">{{ counter }}</button>',
data: function () {
return {
counter: 0
}
},
methods: {
increment: function () {
this.counter += 1;
this.$emit('increment1',"这个位子是可以加参数的");//触发自定义increment1的函数。此处的increment1函数就是 incrementTotal1函数。
// this.$emit('increment2'); //此时不会触发自定义increment2的函数。
}
}
});
new Vue({
el: '#counter-event-example',
data: {
total: 0
},
methods: {
incrementTotal1: function (e) {
this.total += 1;
console.log(e);
},
incrementTotal2: function () {
this.total += 1;
}
}
})
</script>
</html>
因为子组件button-counter绑定了increment方法,所以点击子组件时触发increment,,increment中有this.$emit(increment1),所以触发了increment1Total1函数,则输出的数字加一并且输出“这个位子可以加参数”这句话
因为点击子组件时没有出发increment2,所以在点击第二个按钮时不执行函数increment2