uni.$emit(eventName,Object)
触发全局的自定义事件,附加参数都会传给监听器回调函数。
| 属性 |
类型 |
描述 |
| eventName |
String |
事件名 |
| Object |
Object |
触发全局的自定义事件,附加参数都会传给监听器回调函数。 |
示例代码如下:
uni.$emit('update',{msg:'页面更新'})
uni.$on(eventName,callback)
监听全局的自定义事件,事件由 uni.$emit 触发,回调函数会接收事件触发函数的传入参数。
| 属性 |
类型 |
描述 |
| eventName |
String |
事件名 |
| callback |
Function |
事件的回调函数。 |
示例代码如下:
uni.$on('update',function(data){
console.log('监听到事件来自 update ,携带参数 msg 为:' + data.msg);
})
uni.$once(eventName,callback)
监听全局的自定义事件,事件由 uni.$emit 触发,但仅触发一次,在第一次触发之后移除该监听器。
| 属性 |
类型 |
描述 |
| eventName |
String |
事件名 |
| callback |
Function |
事件的回调函数。 |
uni.$off([eventName, callback])
移除全局自定义事件监听器。
| 属性 |
类型 |
描述 |
| eventName |
String |
事件名 |
| callback |
Function |
事件的回调函数。 |
- 如果uni.$off没有传入参数,则移除App级别的所有事件监听器;
- 如果只提供了事件名(eventName),则移除该事件名对应的所有监听器;
- 如果同时提供了事件与回调,则只移除这个事件回调的监听器;
- 提供的回调必须跟$on的回调为同一个才能移除这个回调的监听器;
代码示例
$emit、$on、$off常用于跨页面、跨组件通讯,这里为了方便演示放在同一个页面。
1 <template>
2 <view class="content">
3 <view class="data">
4 <text>{{val}}</text>
5 </view>
6 <button type="primary" @click="comunicationOff">结束监听</button>
7 </view>
8 </template>
9
10 <script>
11 export default {
12 data() {
13 return {
14 val: 0
15 }
16 },
17 onLoad() {
18 setInterval(()=>{
19 uni.$emit('add', {
20 data: 2
21 })
22 },1000)
23 uni.$on('add', this.add)
24 },
25 methods: {
26 comunicationOff() {
27 uni.$off('add', this.add)
28 },
29 add(e) {
30 this.val += e.data
31 }
32 }
33 }
34 </script>
35
36 <style>
37 .content {
38 display: flex;
39 flex-direction: column;
40 align-items: center;
41 justify-content: center;
42 }
43
44 .data {
45 text-align: center;
46 line-height: 40px;
47 margin-top: 40px;
48 }
49
50 button {
51 width: 200px;
52 margin: 20px 0;
53 }
54 </style>
- uni.$emit、 uni.$on 、 uni.$once 、uni.$off 触发的事件都是 App 全局级别的,跨任意组件,页面,nvue,vue 等
- 使用时,注意及时销毁事件监听,比如,页面 onLoad 里边 uni.$on 注册监听,onUnload 里边 uni.$off 移除,或者一次性的事件,直接使用 uni.$once 监听
参考网址
- 页面通讯:https://uniapp.dcloud.io/api/window/communication?id=emit
有志者,事竟成,破釜沉舟,百二秦关终属楚; 苦心人,天不负,卧薪尝胆,三千越甲可吞吴。
来源:https://www.cnblogs.com/luyj00436/p/15235880.html |