vue学习笔记之给组件绑定原生事件操作示例
2020-04-12 12:08
531 查看
本文实例讲述了vue学习笔记之给组件绑定原生事件操作。分享给大家供大家参考,具体如下:
当在父组件中定义一个点击事件,并且在父组件的methods中定义了这个点击事件时,在页面上点击并不会有什么反应。那么该怎么办呢?
我们可以在子组件的template中的dom上定义一个点击事件(原生事件),并且在子组件的methods中定义该点击事件,然而点击页面时也只会alert(child click )
。
这是为什么呢?父组件的点击事件被vue当成自定义事件,点击后没有检测到,这时需要子组件向父组件触发点击'自定义'事件,即 this.$emit('change')
。then,完成。先响应了child click,然后响应了click。
<!DOCTYPE html> <html lang="en" xmlns:v-bind="http://www.w3.org/1999/xhtml"> <head> <meta charset="UTF-8"> <title>组件参数的校验</title> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> </head> <body> <div id="app"> <child @change="handleClick"></child> <!--此处父组件,相当于自定义事件--> </div> </body> </html> <script> Vue.component('Child', { template: '<div @click="handleChildClick">child</div>', /* 原生事件 */ methods:{ handleChildClick:function () { alert("child click") this.$emit('change') // 向父组件传递自定义事件 } } }) var vm = new Vue({ el: '#app', methods:{ handleClick:function () { alert("click"); } } }) </script>
但是这样好麻烦哦!!怎么办呢?
我们可以直接在父组件定义的@click后面加上native,告诉vue我定义的事件就是原生事件!!就一切?了
like this:
<!DOCTYPE html> <html lang="en" xmlns:v-bind="http://www.w3.org/1999/xhtml"> <head> <meta charset="UTF-8"> <title>组件参数的校验</title> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> </head> <body> <div id="app"> <child @click.native="handleClick"></child> <!--此处声明,原生事件--> </div> </body> </html> <script> Vue.component('Child', { template: '<div>child</div>' }) var vm = new Vue({ el: '#app', methods:{ handleClick:function () { alert("click"); } } }) </script>
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
希望本文所述对大家vue.js程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- vue学习(十二) 给组件绑定原生事件
- Vue学习笔记4.4 绑定原生事件
- Yii框架学习笔记之应用组件操作示例
- vue学习笔记之动态组件和v-once指令简单示例
- Python GUI编程学习笔记之tkinter事件绑定操作详解
- Vue.js学习笔记:v-no绑定事件
- Vue学习笔记2.3 循环、事件绑定与双向绑定
- Vue学习笔记4.1 is方法,全局组件的data, Vue中操作DOM元素
- VUE入门到实战--Vue组件参数校验和非props特性,给组件绑定原生事件
- 给组件绑定原生事件加native修饰符(Vue)
- [Vue] 给组件绑定原生事件
- Vue 2.0学习笔记:实现组件数据的双向绑定
- vue 给自定义组件绑定原生事件
- jQuery学习笔记之DOM操作、事件绑定(2)
- jQuery学习笔记 —— 2. DOM操作和 3. 事件绑定
- jQuery学习笔记之DOM操作、事件绑定(2)
- Vue学习笔记三:阐述单双向数据流绑定及事件绑定
- 【学习笔记】Vue中实现双向数据绑定的原理
- ext4学习笔记(二十)[为Ext的UI组件绑定事件](白鹤翔第一季)
- vue自定义组件和列表循环--vue学习笔记