初识 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源码学习需要哪些工具和技能
【4月更文挑战第20天】学习Vue源码需具备的工具与技能:VS Code或WebStorm作为代码编辑器,Node.js与npm管理依赖,Git操作仓库。基础包括JavaScript、ES6+语法、前端知识(HTML/CSS/浏览器原理)及Vue基础知识。进阶则需源码阅读理解能力,调试技巧,熟悉设计模式和架构思想。学习方法强调系统学习、实践与持续关注Vue最新动态。
17 8
|
1天前
|
JavaScript 前端开发 编译器
Vue 源码学习路线
【4月更文挑战第20天】探索Vue源码涉及响应式系统、虚拟DOM、模板编译等核心概念。先掌握Vue基础知识、JavaScript(ES6+)和前端工程化。从源码入口文件开始,研究响应式、虚拟DOM、模板编译、实例方法、全局API及生命周期。理解编译器和渲染器工作原理,实践编写Vue插件,参与开源项目,阅读相关文章教程,持续关注Vue最新动态。这是一个循序渐进、需要耐心和实践的过程。
7 1
|
1天前
|
JavaScript 前端开发
鼠标监视 | 拖拽方块 | Vue
鼠标监视 | 拖拽方块 | Vue
5 0
|
2天前
|
JavaScript
Vue控制是否禁用disabled属性
Vue控制是否禁用disabled属性
7 1
|
2天前
|
JavaScript 前端开发
Vue鼠标悬浮切换图片
Vue鼠标悬浮切换图片
7 0
|
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父子组件传值