Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
13ec437e
U
uni-app
项目概览
DCloud
/
uni-app
3 个月 前同步成功
通知
725
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,发现更多精彩内容 >>
提交
13ec437e
编写于
12月 28, 2018
作者:
fxy060608
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: 修复页面 onUnload 不触发的 bug
上级
cb0c3123
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
6 addition
and
3 deletion
+6
-3
src/core/service/plugins/app/router-guard.js
src/core/service/plugins/app/router-guard.js
+6
-3
未找到文件。
src/core/service/plugins/app/router-guard.js
浏览文件 @
13ec437e
...
...
@@ -38,7 +38,10 @@ function reLaunch (toName) {
this
.
keepAliveInclude
=
[]
}
let
currentPages
=
[]
function
beforeEach
(
to
,
from
,
next
,
routes
)
{
currentPages
=
getCurrentPages
(
true
)
// 每次 beforeEach 时获取当前currentPages,因为 afterEach 之后,获取不到上一个 page 了,导致无法调用 onUnload
const
fromId
=
from
.
params
.
__id__
const
toId
=
to
.
params
.
__id__
if
(
toId
===
fromId
)
{
// 相同页面阻止
...
...
@@ -97,7 +100,7 @@ function afterEach (to, from) {
const
fromId
=
from
.
params
.
__id__
const
toId
=
to
.
params
.
__id__
const
fromVm
=
getCurrentPages
(
true
).
find
(
pageVm
=>
pageVm
.
$page
.
id
===
fromId
)
const
fromVm
=
currentPages
.
find
(
pageVm
=>
pageVm
.
$page
.
id
===
fromId
)
// 使用 beforeEach 时的 pages
switch
(
to
.
type
)
{
case
'
navigateTo
'
:
// 前一个页面触发 onHide
...
...
@@ -121,10 +124,10 @@ function afterEach (to, from) {
}
if
(
to
.
type
!==
'
reLaunch
'
)
{
// 因为 reLaunch 会重置 id,故不触发 onShow,switchTab 在 beforeRouteEnter 中触发
// 直接获取所有 pages,getCurrentPages 正常情况下仅返回页面栈内,传 true 则返回所有已存在(主要是 tabBar 页面)
const
toVm
=
getCurrentPages
(
true
).
find
(
pageVm
=>
pageVm
.
$page
.
id
===
toId
)
const
toVm
=
getCurrentPages
(
true
).
find
(
pageVm
=>
pageVm
.
$page
.
id
===
toId
)
// 使用最新的 pages
if
(
toVm
)
{
// 目标页面若已存在,则触发 onShow
// 延迟执行 onShow,防止与 UniServiceJSBridge.emit('onHidePopup') 冲突。
setTimeout
(
function
()
{
setTimeout
(
function
()
{
callPageHook
(
toVm
,
'
onShow
'
)
},
0
)
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录