初识 Vue(17)---(给组件绑定原生事件)

简介: 给组件绑定原生事件示例:点击文本弹出警示框 给组件绑定原生事件 Vue.component('child',{ template:'Child' }) var ...

给组件绑定原生事件

示例:点击文本弹出警示框

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>给组件绑定原生事件</title>
	<script src="./vue.js"></script>
</head>
<body>
	<div id="root">
		<child @click="handleClick"></child>
	</div>	
	<script>
	Vue.component('child',{

		template:'<div>Child</div>'
	})

	var vm = new Vue({
		el:'#root',
		methods:{
			handleClick:function(){
				alert('click')
			}
		}
		})
	</script>
</body>
</html>

输出:可以正常输出,但点击没有任何效果

当给一个组件绑定一个事件时候,实际上这个事件是一个自定义的事件(鼠标点击触发的事件并不是真正绑定的事件)

想触发自定义事件,给子组件的元素进行事件绑定,这个事件才是真正原生的事件

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>给组件绑定原生事件</title>
	<script src="./vue.js"></script>
</head>
<body>
	<div id="root">
		<child @click="handleClick"></child>
	</div>	
	<script>
	Vue.component('child',{

		template:'<div @click="handleChildClick">Child</div>',
		methods:{
			handleChildClick:function(){
				this.$emit('click')    //触发自定义事件
			}
		}
	})

	var vm = new Vue({
		el:'#root',
		methods:{
			handleClick:function(){
				alert('click')
			}
		}
		})
	</script>
</body>
</html>

输出:点击 click ---子组件监听到自身的 DIV 被点击---向外触发自定义事件---在组件里监听到自定义事件---

handleClick 事件被执行

更加简便的方法

添加 .native 修饰符,这时就会触发原生事件,而不是自定义事件

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>给组件绑定原生事件</title>
	<script src="./vue.js"></script>
</head>
<body>
	<div id="root">
		<child @click.native="handleClick"></child>
	</div>	
	<script>
	Vue.component('child',{

		template:'<div>Child</div>',
		
	})

	var vm = new Vue({
		el:'#root',
		methods:{
			handleClick:function(){
				alert('click')
			}
		}
		})
	</script>
</body>
</html>

输出:

目录
相关文章
|
1天前
|
JavaScript 前端开发
【vue】iview如何把input输入框和点击输入框之后的边框去掉
【vue】iview如何把input输入框和点击输入框之后的边框去掉
7 0
|
1天前
|
JavaScript
【vue实战】父子组件互相传值
【vue实战】父子组件互相传值
6 1
|
1天前
|
JavaScript
vue2_引入Ant design vue
vue2_引入Ant design vue
6 0
|
1天前
|
JavaScript
vue知识点
vue知识点
10 4
|
8月前
|
JavaScript
Vue的非父子组件之间传值
全局事件总线 一种组件间通信的方式,适用于任意组件间通信
|
7月前
|
缓存 JavaScript 前端开发
Vue Props、Slot、v-once、非父子组件间的传值....
Vue Props、Slot、v-once、非父子组件间的传值....
46 0
|
8月前
|
JavaScript
Vue中父子组件传值
先在⽗组件中给⼦组件的⾃定义属性绑定⼀个⽗组件的变量
|
8月前
|
JavaScript
vue 组件传值
vue 组件传值
43 0
|
8月前
|
JavaScript
vue父子组件传值
vue父子组件传值
|
11月前
|
JavaScript
vue兄弟组件传值 方便快捷
vue兄弟组件传值 方便快捷