vue基础练习-自定义事件

效果图如下:


这里左右两个按钮都是组件,每次点击时组件内部触发click事件,使count值加1,同时触发外部事件,使sum值加

1

<!DOCTYPE html>
<html>
<head>
	<title></title>
	<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
	
</head>
<body>
	<div id="app">
		<div>{{sum}}</div>
		<wang v-on:deliver="addSum"></wang>
		<wang v-on:deliver="addSum"></wang>
	</div>
	<script type="text/javascript">
		Vue.component("wang",{
			template:"<button v-on:click='add'>{{count}}</button>",
			// 这里data需要定义成函数后返回,如果采用字面量写法可能会造成变量污染
			data(){
				return {
					count:0
				}
			},
			methods:{
				add(){
					this.count++;
					// 组件内部触发点击事件时,同时通过$emit方法触发外部自定义事件deliver,这里子组件其实与外部完全解耦了,只是执行内部事件时,同时触发外部事件。
					this.$emit("deliver");
				}
			}
		});
		new Vue({
			el:"#app",
			data:{
				sum:0
			},
			methods:{
				addSum(){
					this.sum++;
				}
			}
		});
	</script>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值