Vue2:给组件绑定自定义事件

一、场景描述

我们在页面开发中,难免要使用事件。

在之前的学习中,我们学过@click、@keyup、@change等事件,这些是Vue自带的事件。

它的使用前提是,只能用在原生的HTML元素上。

比如:

html 复制代码
h1绑定一个click事件。
<h1 @click="test">你好</h1>
iput绑定一个keyup事件.
<input type="text" @keyup.enter="add"/>

这一篇说的自定义事件,可以绑定到我们自己的Vue组件上。

实现子组件给父组件传递数据的功能。

比如:

html 复制代码
<School :getSchoolName="getSchoolName"/>

二、绑定自定义事件

方式1

使用@或v-on方式绑定自定义事件

App父组件中:

模板代码:

html 复制代码
 <Student @test="getStudentName"/>

methods函数:

js 复制代码
getStudentName(name,...params){
    console.log('App收到了学生名:',name,params)
}

Student子组件中:

模板代码:

html 复制代码
<button @click="sendStudentlName">把学生名给App</button>

methods函数:

js 复制代码
//触发Student组件实例身上的test事件	传递多个参数
this.$emit('test',this.name,666,888,900)

方式2

使用ref方式绑定自定义事件
App父组件中:

模板代码:

html 复制代码
<Student ref="student"/>

mounted属性:

js 复制代码
        mounted() {
            //设置三秒后再绑定事件
            // setTimeout(() => {
            //     this.$refs.student.$on('test',this.getStudentName) //绑定自定义事件    第一个参数是事件名称,第二个参数是函数名称
            // },3000);
            // this.$refs.student.$on('test',this.getStudentName) //绑定自定义事件    第一个参数是事件名称,第二个参数是函数名称
            this.$refs.student.$once('test',this.getStudentName) //绑定自定义事件(一次性)
        }

Student子组件中:

方式1相同

三、总结

原则:给那个组件的vc实例绑定事件,就由那个组件的vc实例来触发事件

相对来讲,第二种方法更灵活,第一种方法更简便,各有优势,视具体情况选择使用。

相关推荐
掘金安东尼6 小时前
纯 CSS 实现弹性文字效果
前端·css
牛奶6 小时前
Vue 基础理论 & API 使用
前端·vue.js·面试
牛奶6 小时前
Vue 底层原理 & 新特性
前端·vue.js·面试
anOnion7 小时前
构建无障碍组件之Radio group pattern
前端·html·交互设计
pe7er7 小时前
状态提升:前端开发中的状态管理的设计思想
前端·vue.js·react.js
SoaringHeart8 小时前
Flutter调试组件:打印任意组件尺寸位置信息 NRenderBox
前端·flutter
晚风予星8 小时前
Ant Design Token Lens 迎来了全面升级!支持在 .tsx 或 .ts 文件中直接使用 Design Token
前端·react.js·visual studio code
sunny_8 小时前
⚡️ vite-plugin-oxc:从 Babel 到 Oxc,我为 Vite 写了一个高性能编译插件
前端·webpack·架构
GIS之路8 小时前
ArcPy 开发环境搭建
前端
林小帅10 小时前
【笔记】OpenClaw 架构浅析
前端·agent