Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
f43230ed
U
uni-app
项目概览
DCloud
/
uni-app
4 个月 前同步成功
通知
726
Star
38705
Fork
3642
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
7
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
7
Issue
7
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
f43230ed
编写于
10月 31, 2019
作者:
fxy060608
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(v3): postMessage
上级
3321b0aa
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
72 addition
and
26 deletion
+72
-26
packages/uni-app-plus/dist/index.v3.js
packages/uni-app-plus/dist/index.v3.js
+36
-12
src/core/service/bridge/on.js
src/core/service/bridge/on.js
+1
-14
src/platforms/app-plus/service/framework/subscribe-handlers/index.js
...ms/app-plus/service/framework/subscribe-handlers/index.js
+2
-0
src/platforms/app-plus/service/framework/subscribe-handlers/on-web-invoke-app-service.js
...framework/subscribe-handlers/on-web-invoke-app-service.js
+33
-0
未找到文件。
packages/uni-app-plus/dist/index.v3.js
浏览文件 @
f43230ed
...
...
@@ -9326,15 +9326,6 @@ var serviceContext = (function () {
callCurrentPageHook
(
'
onShow
'
);
}
function
onWebInvokeAppService
({
name
,
arg
},
pageIds
)
{
if
(
name
===
'
postMessage
'
)
;
else
{
uni
[
name
](
arg
);
}
}
const
routeHooks
=
{
navigateTo
()
{
callCurrentPageHook
(
'
onHide
'
);
...
...
@@ -9368,9 +9359,7 @@ var serviceContext = (function () {
on
(
'
onNavigationBarSearchInputChanged
'
,
createCallCurrentPageHook
(
'
onNavigationBarSearchInputChanged
'
));
on
(
'
onNavigationBarSearchInputConfirmed
'
,
createCallCurrentPageHook
(
'
onNavigationBarSearchInputConfirmed
'
));
on
(
'
onNavigationBarSearchInputClicked
'
,
createCallCurrentPageHook
(
'
onNavigationBarSearchInputClicked
'
));
on
(
'
onWebInvokeAppService
'
,
onWebInvokeAppService
);
on
(
'
onNavigationBarSearchInputClicked
'
,
createCallCurrentPageHook
(
'
onNavigationBarSearchInputClicked
'
));
}
function
initSubscribe
(
subscribe
,
{
...
...
@@ -9526,6 +9515,40 @@ var serviceContext = (function () {
uni
[
method
]
&&
uni
[
method
](
args
);
}
function
onMessage
(
pageId
,
arg
)
{
pageId
=
parseInt
(
pageId
);
const
page
=
getCurrentPages
(
true
).
find
(
page
=>
page
.
$page
.
id
===
pageId
);
if
(
!
page
)
{
return
}
if
(
!
page
.
$page
.
meta
.
isNVue
)
{
const
target
=
page
.
$vm
.
_$vd
.
elements
.
find
(
target
=>
target
.
tagName
===
'
web-view
'
&&
target
.
events
[
'
message
'
]);
if
(
!
target
)
{
return
}
target
.
dispatchEvent
(
'
message
'
,
{
type
:
'
message
'
,
target
:
Object
.
create
(
null
),
currentTarget
:
Object
.
create
(
null
),
timeStamp
:
Date
.
now
(),
detail
:
{
data
:
[
arg
]
}
});
}
}
function
onWebInvokeAppService
({
name
,
arg
},
pageIds
)
{
if
(
name
===
'
postMessage
'
)
{
onMessage
(
pageIds
[
0
],
arg
);
}
else
{
uni
[
name
](
arg
);
}
}
function
initSubscribeHandlers
()
{
const
{
on
,
...
...
@@ -9556,6 +9579,7 @@ var serviceContext = (function () {
on
(
'
api.
'
+
WEB_INVOKE_APPSERVICE$1
,
function
(
data
,
webviewIds
)
{
emit
(
'
onWebInvokeAppService
'
,
data
,
webviewIds
);
});
on
(
'
onWebInvokeAppService
'
,
onWebInvokeAppService
);
subscribe
(
VD_SYNC
,
onVdSync
);
subscribe
(
VD_SYNC_CALLBACK
,
onVdSyncCallback
);
...
...
src/core/service/bridge/on.js
浏览文件 @
f43230ed
...
...
@@ -50,17 +50,6 @@ export default function initOn (on, {
callCurrentPageHook
(
'
onShow
'
)
}
function
onWebInvokeAppService
({
name
,
arg
},
pageIds
)
{
if
(
name
===
'
postMessage
'
)
{
// TODO 小程序后退、组件销毁、分享时通知
}
else
{
uni
[
name
](
arg
)
}
}
const
routeHooks
=
{
navigateTo
()
{
callCurrentPageHook
(
'
onHide
'
)
...
...
@@ -94,7 +83,5 @@ export default function initOn (on, {
on
(
'
onNavigationBarSearchInputChanged
'
,
createCallCurrentPageHook
(
'
onNavigationBarSearchInputChanged
'
))
on
(
'
onNavigationBarSearchInputConfirmed
'
,
createCallCurrentPageHook
(
'
onNavigationBarSearchInputConfirmed
'
))
on
(
'
onNavigationBarSearchInputClicked
'
,
createCallCurrentPageHook
(
'
onNavigationBarSearchInputClicked
'
))
on
(
'
onWebInvokeAppService
'
,
onWebInvokeAppService
)
on
(
'
onNavigationBarSearchInputClicked
'
,
createCallCurrentPageHook
(
'
onNavigationBarSearchInputClicked
'
))
}
src/platforms/app-plus/service/framework/subscribe-handlers/index.js
浏览文件 @
f43230ed
...
...
@@ -18,6 +18,7 @@ import onVdSync from './on-vd-sync'
import
onVdSyncCallback
from
'
./on-vd-sync-callback
'
import
onInvokeApi
from
'
./on-invoke-api
'
import
onWebInvokeAppService
from
'
./on-web-invoke-app-service
'
export
function
initSubscribeHandlers
()
{
const
{
...
...
@@ -49,6 +50,7 @@ export function initSubscribeHandlers () {
on
(
'
api.
'
+
WEB_INVOKE_APPSERVICE
,
function
(
data
,
webviewIds
)
{
emit
(
'
onWebInvokeAppService
'
,
data
,
webviewIds
)
})
on
(
'
onWebInvokeAppService
'
,
onWebInvokeAppService
)
subscribe
(
VD_SYNC
,
onVdSync
)
subscribe
(
VD_SYNC_CALLBACK
,
onVdSyncCallback
)
...
...
src/platforms/app-plus/service/framework/subscribe-handlers/on-web-invoke-app-service.js
0 → 100644
浏览文件 @
f43230ed
function
onMessage
(
pageId
,
arg
)
{
pageId
=
parseInt
(
pageId
)
const
page
=
getCurrentPages
(
true
).
find
(
page
=>
page
.
$page
.
id
===
pageId
)
if
(
!
page
)
{
return
}
if
(
!
page
.
$page
.
meta
.
isNVue
)
{
const
target
=
page
.
$vm
.
_$vd
.
elements
.
find
(
target
=>
target
.
tagName
===
'
web-view
'
&&
target
.
events
[
'
message
'
])
if
(
!
target
)
{
return
}
target
.
dispatchEvent
(
'
message
'
,
{
type
:
'
message
'
,
target
:
Object
.
create
(
null
),
currentTarget
:
Object
.
create
(
null
),
timeStamp
:
Date
.
now
(),
detail
:
{
data
:
[
arg
]
}
})
}
}
export
default
function
onWebInvokeAppService
({
name
,
arg
},
pageIds
)
{
if
(
name
===
'
postMessage
'
)
{
onMessage
(
pageIds
[
0
],
arg
)
}
else
{
uni
[
name
](
arg
)
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录