Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Velpro187
uni-app
提交
0de1f3f0
U
uni-app
项目概览
Velpro187
/
uni-app
与 Fork 源项目一致
Fork自
DCloud / uni-app
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
0de1f3f0
编写于
8月 29, 2022
作者:
fxy060608
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(push): lazy add listener
上级
f7b09e6a
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
34 addition
and
35 deletion
+34
-35
packages/uni-api/src/service/plugin/push.ts
packages/uni-api/src/service/plugin/push.ts
+17
-0
packages/uni-app-plus/dist/uni.runtime.esm.js
packages/uni-app-plus/dist/uni.runtime.esm.js
+17
-0
packages/uni-push/dist/uni-push.es.js
packages/uni-push/dist/uni-push.es.js
+0
-7
packages/uni-push/dist/uni-push.plus.es.js
packages/uni-push/dist/uni-push.plus.es.js
+0
-14
packages/uni-push/src/plus.ts
packages/uni-push/src/plus.ts
+0
-7
packages/uni-push/src/route.ts
packages/uni-push/src/route.ts
+0
-7
未找到文件。
packages/uni-api/src/service/plugin/push.ts
浏览文件 @
0de1f3f0
...
...
@@ -134,8 +134,25 @@ interface OnPushMessageSuccess {
type
OnPushMessageCallback
=
(
result
:
OnPushMessageSuccess
)
=>
void
const
onPushMessageCallbacks
:
OnPushMessageCallback
[]
=
[]
let
listening
=
false
// 不使用 defineOnApi 实现,是因为 defineOnApi 依赖 UniServiceJSBridge ,该对象目前在小程序上未提供,故简单实现
export
const
onPushMessage
:
(
fn
:
OnPushMessageCallback
)
=>
void
=
(
fn
)
=>
{
// 不能程序启动时就监听,因为离线事件,仅触发一次,框架监听后,无法转发给还没开始监听的开发者
if
(
__PLATFORM__
===
'
app
'
&&
!
listening
)
{
listening
=
true
plus
.
push
.
addEventListener
(
'
click
'
,
(
result
)
=>
{
invokePushCallback
({
type
:
'
click
'
,
message
:
result
,
})
})
plus
.
push
.
addEventListener
(
'
receive
'
,
(
result
)
=>
{
invokePushCallback
({
type
:
'
pushMsg
'
,
message
:
result
,
})
})
}
if
(
onPushMessageCallbacks
.
indexOf
(
fn
)
===
-
1
)
{
onPushMessageCallbacks
.
push
(
fn
)
}
...
...
packages/uni-app-plus/dist/uni.runtime.esm.js
浏览文件 @
0de1f3f0
...
...
@@ -11160,8 +11160,25 @@ const getPushClientId = defineAsyncApi(API_GET_PUSH_CLIENT_ID, (_, { resolve, re
});
});
const onPushMessageCallbacks = [];
let listening = false;
// 不使用 defineOnApi 实现,是因为 defineOnApi 依赖 UniServiceJSBridge ,该对象目前在小程序上未提供,故简单实现
const onPushMessage = (fn) => {
// 不能程序启动时就监听,因为离线事件,仅触发一次,框架监听后,无法转发给还没开始监听的开发者
if (!listening) {
listening = true;
plus.push.addEventListener('click', (result) => {
invokePushCallback({
type: 'click',
message: result,
});
});
plus.push.addEventListener('receive', (result) => {
invokePushCallback({
type: 'pushMsg',
message: result,
});
});
}
if (onPushMessageCallbacks.indexOf(fn) === -1) {
onPushMessageCallbacks.push(fn);
}
...
...
packages/uni-push/dist/uni-push.es.js
浏览文件 @
0de1f3f0
...
...
@@ -133,13 +133,6 @@ function initPushNotification() {
},
});
});
plus
.
push
.
addEventListener
(
'
click
'
,
(
result
)
=>
{
// @ts-expect-error
uni
.
invokePushCallback
({
type
:
'
click
'
,
message
:
result
,
});
});
uni
.
onPushMessage
((
res
)
=>
{
if
(
res
.
type
===
'
receive
'
&&
res
.
data
&&
...
...
packages/uni-push/dist/uni-push.plus.es.js
浏览文件 @
0de1f3f0
...
...
@@ -31,13 +31,6 @@ function initPushNotification() {
},
});
});
plus
.
push
.
addEventListener
(
'
click
'
,
(
result
)
=>
{
// @ts-expect-error
uni
.
invokePushCallback
({
type
:
'
click
'
,
message
:
result
,
});
});
uni
.
onPushMessage
((
res
)
=>
{
if
(
res
.
type
===
'
receive
'
&&
res
.
data
&&
...
...
@@ -58,11 +51,4 @@ uni.invokePushCallback({
Promise
.
resolve
().
then
(()
=>
{
initPushNotification
();
plus
.
push
.
setAutoNotification
&&
plus
.
push
.
setAutoNotification
(
false
);
plus
.
push
.
addEventListener
(
'
receive
'
,
(
result
)
=>
{
// @ts-expect-error
uni
.
invokePushCallback
({
type
:
'
pushMsg
'
,
message
:
result
,
});
});
});
packages/uni-push/src/plus.ts
浏览文件 @
0de1f3f0
...
...
@@ -8,11 +8,4 @@ uni.invokePushCallback({
Promise
.
resolve
().
then
(()
=>
{
initPushNotification
()
plus
.
push
.
setAutoNotification
&&
plus
.
push
.
setAutoNotification
(
false
)
plus
.
push
.
addEventListener
(
'
receive
'
,
(
result
)
=>
{
// @ts-expect-error
uni
.
invokePushCallback
({
type
:
'
pushMsg
'
,
message
:
result
,
})
})
})
packages/uni-push/src/route.ts
浏览文件 @
0de1f3f0
...
...
@@ -35,13 +35,6 @@ export function initPushNotification() {
})
}
)
plus
.
push
.
addEventListener
(
'
click
'
,
(
result
)
=>
{
// @ts-expect-error
uni
.
invokePushCallback
({
type
:
'
click
'
,
message
:
result
,
})
})
uni
.
onPushMessage
((
res
)
=>
{
if
(
res
.
type
===
'
receive
'
&&
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录