
简体中文
监听自定义事件。事件可以由 uni.$emit 触发。回调函数会接收 uni.$emit 传递的参数。 4.31+ 开始支持返回事件监听器 id, 用于 off 事件监听器。
Web | 微信小程序 | Android | iOS | iOS uni-app x UTS 插件 | HarmonyOS |
---|---|---|---|---|---|
4.0 | 4.41 | 3.91 | 4.11 | 4.31 | 4.61 |
名称 | 类型 | 必填 | 默认值 | 兼容性 | 描述 |
---|---|---|---|---|---|
eventName | string | 是 | - | - | 事件名称 |
callback | () => void | 是 | - | - | 事件回调 |
类型 |
---|
number |
移除自定义事件监听器。如果提供了事件名和回调,则只移除这个回调的监听器。
4.13+ 开始支持第二个参数为可选,如果仅提供事件名,则移除该事件的所有监听器。
4.31+ 开始第二个参数的类型由 Function | null
调整为 any | null
, 支持传入 uni.$on
、uni.$once
返回的事件监听器 id, 移除指定事件监听器。
Web | 微信小程序 | Android | iOS | iOS uni-app x UTS 插件 | HarmonyOS |
---|---|---|---|---|---|
4.0 | 4.41 | 3.91 | 4.11 | 4.31 | 4.61 |
名称 | 类型 | 必填 | 默认值 | 兼容性 | 描述 |
---|---|---|---|---|---|
eventName | string | 是 | - | - | 事件名称 |
callback | any | 否 | - | - | 要移除的事件回调或事件监听器 id |
监听一个自定义事件。事件只触发一次,在第一次触发之后移除事件监听器。 4.31+ 开始支持返回事件监听器 id, 用于 off 事件监听器。
Web | 微信小程序 | Android | iOS | iOS uni-app x UTS 插件 | HarmonyOS |
---|---|---|---|---|---|
4.0 | 4.41 | 3.91 | 4.11 | 4.31 | 4.61 |
名称 | 类型 | 必填 | 默认值 | 兼容性 | 描述 |
---|---|---|---|---|---|
eventName | string | 是 | - | - | 事件名称 |
callback | () => void | 是 | - | - | 事件回调 |
类型 |
---|
number |
触发自定义事件,附加的参数会传递给事件监听器。 在iOS平台UTS环境下或者UTS和JS通信时参数仅支持基础类型、string、Array、UTSJSONObject,其中Array,UTSJSONObject也仅支持包含上述类型,on和emit类型需匹配否则会产生异常
Web | 微信小程序 | Android | iOS | iOS uni-app x UTS 插件 | HarmonyOS |
---|---|---|---|---|---|
4.0 | 4.41 | 3.91 | 4.11 | 4.31 | 4.61 |
名称 | 类型 | 必填 | 默认值 | 兼容性 | 描述 |
---|---|---|---|---|---|
eventName | string | 是 | - | - | 事件名称 |
args | Array<any> | 否 | - | - | 触发事件时传递的参数 |
WARNING
参数 args
为对象字面量时,4.25 前需要通过 as
明确类型,例如:
uni.$emit('fn', {"a": 1} as UTSJSONObject)
4.25+ 编译器会自动将对象字面量推断为 UTSJSONObject
类型,不再需要通过 as
明确类型。如果需要传递其他自定义类型的对象字面量,仍需要通过 as
明确类型。
示例为hello uni-app x alpha分支,与最新HBuilderX Alpha版同步。与最新正式版同步的master分支示例另见
示例
<template>
<!-- #ifdef APP -->
<scroll-view class="page-scroll-view">
<!-- #endif -->
<view class="box">
<button class="uni-btn" @click="on">开始监听</button>
<button class="uni-btn" @click="once">监听一次</button>
<button class="uni-btn" @click="off">取消监听</button>
<!-- <button @click="offAll">取消全部监听</button> -->
<button class="uni-btn" @click="emit">触发监听</button>
<button class="uni-btn" @click="clear">清空消息</button>
<view>
<view class="uni-btn">收到的消息:</view>
<view class="uni-btn">
<view v-for="(item, index) in log" :key="index">{{ item }}</view>
</view>
<button class="uni-btn" @click="onObj">开始监听 obj 参数</button>
<button class="uni-btn" @click="emitWithObj">触发监听 obj 参数</button>
<view class='uni-btn'>
<text>接收到的 obj 参数:</text>
<text>{{ JSON.stringify(objArg) }}</text>
</view>
<button class='uni-btn' @click="testReturnId">测试返回 id</button>
<button class='uni-btn' @click="testEmitNoArgs">测试 $emit 无参</button>
<button class='uni-btn' @click="testEmitMultipleArgs">测试 $emit 多个参数</button>
</view>
</view>
<!-- #ifdef APP -->
</scroll-view>
<!-- #endif -->
</template>
<script>
export default {
data() {
return {
log: [] as string[],
objArg: {},
}
},
methods: {
fn(res : string) {
this.log.push(res)
},
fn2(res : string) {
this.log.push(res)
},
on() {
uni.$on('test', this.fn)
},
on2() {
uni.$on('test', this.fn2)
},
onObj() {
uni.$on('test-obj', (res : UTSJSONObject) => {
this.objArg = res
})
},
once() {
uni.$once('test', this.fn)
},
off() {
uni.$off('test', this.fn)
},
offAll() {
uni.$off('test')
},
emit() {
uni.$emit('test', 'msg:' + Date.now())
},
emitWithObj() {
uni.$emit('test-obj', { a: 1, b: 2 })
},
clear() {
this.log.length = 0
},
testReturnId(){
const id1 = uni.$on('test-return-id', this.fn)
uni.$emit('test-return-id', '触发 test-return-id $on fn')
uni.$off('test-return-id', id1)
uni.$emit('test-return-id', '触发 test-return-id $on fn')
uni.$once('test-return-id', this.fn)
uni.$emit('test-return-id', '触发 test-return-id $once fn')
uni.$emit('test-return-id', '触发 test-return-id $once fn')
const id2 = uni.$once('test-id', this.fn)
uni.$off('test-return-id', id2)
uni.$emit('test-return-id', '触发 test-return-id $once fn')
},
testEmitNoArgs() {
uni.$on('test-emit-no-args', () => {
this.log.push('test-emit-no-args')
})
uni.$emit('test-emit-no-args')
uni.$off('test-emit-no-args')
},
testEmitMultipleArgs() {
uni.$on('test-emit-multiple-args', (arg1 : string, arg2 : number) => {
this.log.push(`${arg1}_${arg2}`)
})
uni.$emit('test-emit-multiple-args', 'arg1', 2)
uni.$off('test-emit-multiple-args')
}
},
}
</script>
<style>
.box {
padding: 10px;
}
</style>
名称 | 类型 | 必备 | 默认值 | 兼容性 | 描述 |
---|---|---|---|---|---|
errMsg | string | 是 | - | 错误信息 |
eventName
应避免使用 uni
开头,以免与 uni-app x 内置事件冲突