Vue之组件的自定义事件详解
更新时间:2021年11月21日 11:09:25 作者:王同学要努力
这篇文章主要为大家介绍了Vue之组件的自定义事件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
<template> <div > <h2>{{msg}}</h2> <!-- 通过父组件给子组件传递函数类型的数据props实现:子给父传递数据 --> <School :getName="getName"/> <Student :getStudentname="getStudentname"/> <!-- 通过父组件给子组件绑定一个自定义事件:实现子给父传递数据 --> <Age v-on:elderSex="demo"/> <!-- 通过父组件给子组件绑定一个自定义事件实现:子给父传递数据(第二种写法:使用ref) --> <!-- <Student ref="student"/> --> </div> </template> <script> import School from './components/School.vue' import Student from './components/Student.vue' import Age from './components/Age.vue' export default { name:'App', components:{ School,Student ,Age}, data(){ return { msg:'你好,世界!' } }, methods:{ getName(name){ console.log('App收到了名字',name); }, getStudentname(name1){ console.log('接收到了学生的姓名',name1); }, demo(sex1){ console.log( 'demo被调用了',sex1); } }, // mounted() { //绑定自定义事件 // this.$refs.student.$on('elderSex',this.schoolAge) //绑定自定义事件(一次性) // this.$refs.student.$once('elderSex',this.schoolAge) // }, } </script> <style scoped> </style>
<template> <div class="demo"> <h2>学生姓名:{{name}}</h2> <h2>学生年龄:{{age}}</h2> <button @click="sendStudentname">把学生的名字给APP</button> </div> </template> <script> export default { name: 'Student', props: ['getStudentname'], data() { return { name: '张三', age: 19 } }, methods: { sendStudentname() { this.getStudentname(this.name) } } } </script> <style> .demo { background-color: skyblue; } </style>
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!
相关文章
Ant Design Vue 走马灯实现单页多张图片轮播效果
这篇文章主要介绍了Ant Design Vue 走马灯实现单页多张图片轮播,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-07-07
最新评论