Vue- 组件自定义事件 (绑定和解绑)
组件自定义事件(绑定)
像 click,change 这些都是 js 的内置事件,我们可以直接使用,本次我们学习自己根据需求打造全新的事件,但是 js 内置的是给 html 元素用的,本次的自定义事件是给组件用的
注意:组件上也可以绑定原生 DOM 事件,需要使用 native 修饰符,销毁组件实例也会销毁组件对应的自定义事件
下面通过案例说明
1 编写案例
如图,我有三个组件,分别是学生,学校和 app,由 app 管理其他两个组件,这时候想给学校组件一个按钮,点击的时候会把学校名称交给 app
data:image/s3,"s3://crabby-images/38844/3884438861b2b10863344f9fe15cf6fa0994c4d7" alt=""
2 props 实现
通过父组件给子组件传递函数类型的 props 实现:子给父传递数据
我们可以子组件使用 props 给父组件传递,所以首先在 app 里面定义函数,然后通过 props 进行传递使用
data:image/s3,"s3://crabby-images/2f600/2f600177c9d2c82ba42f2603ac69a9b849d5a3a2" alt=""
data:image/s3,"s3://crabby-images/9dce5/9dce57ea5ac7d7bf0861215bac1b35183b48f566" alt=""
3 自定义事件实现方式 1
如果我还想继续给 student 一个按钮,点击的时候把学生姓名给 app 组件呢?这次不用 props 了,使用自定义事件实现
通过父组件给子组件绑定自定义事件实现:子给父传递数据
使用 $emit 触发组件身上的自定义事件,参数是事件名称
当然,使用 @简写形式替代 v-on 也是可以的,我这里没有简写,事件名称和回调名称可以相同的
data:image/s3,"s3://crabby-images/a9d44/a9d4449820fd55aac98893ff4656a22e0d873aac" alt=""
也是可以完成的
data:image/s3,"s3://crabby-images/da46b/da46b3fe7619ee2063861f9d315e7b621d21a217" alt=""
4 自定义事件实现方式 2
除了上述的方式,还有另外一种方式可以实现,使用 ref,写一个加载钩子函数,使用 $on
这种写法虽然麻烦,需要写钩子函数,但是它也更加的灵活
data:image/s3,"s3://crabby-images/34531/34531188e1a50569588465c9d0a13f9baa8e426d" alt=""
效果都是一样的
data:image/s3,"s3://crabby-images/cc385/cc385c9d5734ed791d3c74734687e0c10d2af7ee" alt=""
如果验证它更加的灵活呢?比如现在有这样的一个需求,需要 3 秒后才能加载事件,这时候使用第一种写法就写不了,但是第二种写法就可以
data:image/s3,"s3://crabby-images/eb715/eb71521c013cdfd02d5833d8da9575e05a5ea714" alt=""
5 只能触发一次事件
有的场景,我想要自定义事件触发一次后就不再触发了,这时候就不能使用once
data:image/s3,"s3://crabby-images/60cf8/60cf8f2c08dff744f9f3b137b38c8ba904051088" alt=""
如果不是这种写法呢?也是一样的道理,在事件名称后.once 即可
data:image/s3,"s3://crabby-images/10794/1079439af5e326bf32899b7ecc0552b52ef94102" alt=""
6 多个参数传递
自定义事件也是可以支持传递多个参数的,使用逗号拼接即可
data:image/s3,"s3://crabby-images/c913d/c913d189a98f5f7ef60ce1a7c15b2f581aebba77" alt=""
data:image/s3,"s3://crabby-images/b6620/b662020f196329bf6855eac400cd0e7434151a18" alt=""
但是一般多个参数不会这么写,而是使用 es6 里面的...params 接收,他会把多个参数拼接成一个数组
data:image/s3,"s3://crabby-images/315dd/315dd9bc3510213520a70e4e48af3ee79e5a074d" alt=""
data:image/s3,"s3://crabby-images/fe336/fe3367d4397ef8fb0bc9abfd8988a6bc02f7a243" alt=""
组件自定义事件(解绑)
上面介绍了绑定自定义事件,接下来就是对应的解绑自定义事件
1 解绑一个事件
使用 $off 解绑,参数就是事件名称,这种写法只支持解绑一个事件
data:image/s3,"s3://crabby-images/3628b/3628bb64b9d9cc94a82d97e15379b7bf5de9703d" alt=""
那么多个该如何操作呢?
2 解绑多个事件
比如现在有两个自定义事件
data:image/s3,"s3://crabby-images/bce86/bce86763f1541497ca80e9c9fae953039c230e3e" alt=""
data:image/s3,"s3://crabby-images/58df5/58df51e56040dbe648a13f8f2ea7c5986f00f7f3" alt=""
使用 $off 解绑,参数是一个数组,里面是参数名称
data:image/s3,"s3://crabby-images/a0638/a0638eeda890e1e6f8ee772f3d5b773db8a18629" alt=""
3 解绑全部事件
还有一种更加暴力的写法,使用 off 方法什么也不传,这便是解绑全部事件
data:image/s3,"s3://crabby-images/44e87/44e8708c4c3ae4c1ac614d67bf1bfe170d61b57d" alt=""
组件的自定义事件总结
一种组件间通信的方式,适用于:<strong style="color:red">子组件 ===> 父组件</strong>
使用场景:A 是父组件,B 是子组件,B 想给 A 传数据,那么就要在 A 中给 B 绑定自定义事件(<span style="color:red">事件的回调在 A 中</span>)。
绑定自定义事件:
第一种方式,在父组件中:
<Demo @atguigu="test"/>
或<Demo v-on:atguigu="test"/>
第二种方式,在父组件中:
若想让自定义事件只能触发一次,可以使用
once
修饰符,或$once
方法。触发自定义事件:
this.$emit('atguigu',数据)
解绑自定义事件
this.$off('atguigu')
组件上也可以绑定原生 DOM 事件,需要使用
native
修饰符。注意:通过
this.$refs.xxx.$on('atguigu',回调)
绑定自定义事件时,回调<span style="color:red">要么配置在 methods 中</span>,<span style="color:red">要么用箭头函数</span>,否则 this 指向会出问题!# 组件自定义事件(绑定)像 click,change 这些都是 js 的内置事件,我们可以直接使用,本次我们学习自己根据需求打造全新的事件,但是 js 内置的是给 html 元素用的,本次的自定义事件是给组件用的
注意:组件上也可以绑定原生 DOM 事件,需要使用 native 修饰符,销毁组件实例也会销毁组件对应的自定义事件
下面通过案例说明
## 1 编写案例
如图,我有三个组件,分别是学生,学校和 app,由 app 管理其他两个组件,这时候想给学校组件一个按钮,点击的时候会把学校名称交给 app
data:image/s3,"s3://crabby-images/36f57/36f57609bc162ee7e2e7d8b27fc9acb32711e592" alt=""
## 2 props 实现
通过父组件给子组件传递函数类型的 props 实现:子给父传递数据
我们可以子组件使用 props 给父组件传递,所以首先在 app 里面定义函数,然后通过 props 进行传递使用
data:image/s3,"s3://crabby-images/2ee49/2ee495f099e8134504160f58f6beda1fe4ea5bcf" alt=""
data:image/s3,"s3://crabby-images/37e96/37e9690444a942f350147008da1339667e734296" alt=""
## 3 自定义事件实现方式 1
如果我还想继续给 student 一个按钮,点击的时候把学生姓名给 app 组件呢?这次不用 props 了,使用自定义事件实现
通过父组件给子组件绑定自定义事件实现:子给父传递数据
使用 $emit 触发组件身上的自定义事件,参数是事件名称
当然,使用 @简写形式替代 v-on 也是可以的,我这里没有简写,事件名称和回调名称可以相同的
data:image/s3,"s3://crabby-images/e42a9/e42a9da715f82ad83ffb0cb07b99a0fcf8966af8" alt=""
也是可以完成的
data:image/s3,"s3://crabby-images/d0594/d0594a212a751217a3242a0bfa58966b9c2d420a" alt=""
## 4 自定义事件实现方式 2
除了上述的方式,还有另外一种方式可以实现,使用 ref,写一个加载钩子函数,使用 $on
这种写法虽然麻烦,需要写钩子函数,但是它也更加的灵活
data:image/s3,"s3://crabby-images/01b94/01b9404185fa736c3f33b744284f7da58a95f2b3" alt=""
效果都是一样的
data:image/s3,"s3://crabby-images/af8f8/af8f81f32c660962bab56c8a4e118d8677e5e300" alt=""
如果验证它更加的灵活呢?比如现在有这样的一个需求,需要 3 秒后才能加载事件,这时候使用第一种写法就写不了,但是第二种写法就可以
data:image/s3,"s3://crabby-images/0838f/0838fc61c3c58bd0d4e092560b658f9c72e8dd9e" alt=""
## 5 只能触发一次事件
有的场景,我想要自定义事件触发一次后就不再触发了,这时候就不能使用 $on 这个 api 了,应该使用 $once
data:image/s3,"s3://crabby-images/7b7a5/7b7a541a9899e2b09f422dc210a3ace6a5577b55" alt=""
如果不是这种写法呢?也是一样的道理,在事件名称后.once 即可
data:image/s3,"s3://crabby-images/2b4d5/2b4d5345506d5fd28f9882ed3f2a6a0b3f17454b" alt=""
## 6 多个参数传递
自定义事件也是可以支持传递多个参数的,使用逗号拼接即可
data:image/s3,"s3://crabby-images/7669f/7669f6463eba6f8ac22a14811be4a6fad30eb1a3" alt=""
data:image/s3,"s3://crabby-images/645e7/645e7670aef596ca560bbfd0c3ff462c49f19dd9" alt=""
但是一般多个参数不会这么写,而是使用 es6 里面的...params 接收,他会把多个参数拼接成一个数组
data:image/s3,"s3://crabby-images/ab697/ab6974760654920692b5e482375d70771e6987b9" alt=""
data:image/s3,"s3://crabby-images/ab1b7/ab1b79cfda5a957ea6f6a7ba3f275a6ca177b092" alt=""
# 组件自定义事件(解绑)
上面介绍了绑定自定义事件,接下来就是对应的解绑自定义事件
## 1 解绑一个事件
使用 $off 解绑,参数就是事件名称,这种写法只支持解绑一个事件
data:image/s3,"s3://crabby-images/16c5d/16c5d02cf0aff835488a539be600eff6fa697d93" alt=""
那么多个该如何操作呢?
## 2 解绑多个事件
比如现在有两个自定义事件
data:image/s3,"s3://crabby-images/aa454/aa454d0f5af4563a8d2af04a314214303d8c7dc5" alt=""
data:image/s3,"s3://crabby-images/5a8b9/5a8b91cac229819f0cb07cacc61fdaa0cd9b45d7" alt=""
使用 $off 解绑,参数是一个数组,里面是参数名称
data:image/s3,"s3://crabby-images/0c3db/0c3dbe840726a7b358a3fa084f4c10557a335619" alt=""
## 3 解绑全部事件
还有一种更加暴力的写法,使用 off 方法什么也不传,这便是解绑全部事件
data:image/s3,"s3://crabby-images/a4034/a403423e0a18101e8fe7cc2aabfd5f832073d2b8" alt=""
# 组件的自定义事件总结
1. 一种组件间通信的方式,适用于:<strong style="color:red">子组件 ===> 父组件</strong>
2. 使用场景:A 是父组件,B 是子组件,B 想给 A 传数据,那么就要在 A 中给 B 绑定自定义事件(<span style="color:red">事件的回调在 A 中</span>)。
3. 绑定自定义事件:
1. 第一种方式,在父组件中:```<Demo @atguigu="test"/>``` 或 ```<Demo v-on:atguigu="test"/>```
2. 第二种方式,在父组件中:
```js
<Demo ref="demo"/>
......
mounted(){
this.$refs.xxx.$on('atguigu',this.test)
}
```
3. 若想让自定义事件只能触发一次,可以使用```once```修饰符,或```$once```方法。
4. 触发自定义事件:```this.$emit('atguigu',数据)```
5. 解绑自定义事件```this.$off('atguigu')```
6. 组件上也可以绑定原生 DOM 事件,需要使用```native```修饰符。
7. 注意:通过```this.$refs.xxx.$on('atguigu',回调)```绑定自定义事件时,回调<span style="color:red">要么配置在 methods 中</span>,<span style="color:red">要么用箭头函数</span>,否则 this 指向会出问题!
评论