uni-app之页面通讯——uni.$emit、uni.$on、uni.$once、uni$off

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 监听

参考网址

posted @ 2021-09-06 21:41  陆陆无为而治者  阅读(3649)  评论(0编辑  收藏  举报