框架以栈的形式维护了当前的所有页面。 当发生路由切换的时候,页面栈的表现如下:
路由方式 |
页面栈表现 |
初始化 |
新页面入栈 |
打开新页面 |
新页面入栈 |
页面重定向 |
当前页面出栈,新页面入栈 |
页面返回 |
页面不断出栈,直到目标返回页,新页面入栈 |
Tab 切换 |
页面全部出栈,只留下新的 Tab 页面 |
重加载 |
页面全部出栈,只留下新的页面 |
getCurrentPages()
getCurrentPages() 函数用于获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面。
Tab 切换对应的生命周期(以 A、B 页面为 Tabbar 页面,C 是从 A 页面打开的页面,D 页面是从 C 页面打开的页面为例):
当前页面 |
路由后页面 |
触发的生命周期(按顺序) |
A |
A |
Nothing happend |
A |
B |
A.onHide(), B.onLoad(), B.onShow() |
A |
B(再次打开) |
A.onHide(), B.onShow() |
C |
A |
C.onUnload(), A.onShow() |
C |
B |
C.onUnload(), B.onLoad(), B.onShow() |
D |
B |
D.onUnload(), C.onUnload(), B.onLoad(), B.onShow() |
D(从转发进入) |
A |
D.onUnload(), A.onLoad(), A.onShow() |
D(从转发进入) |
B |
D.onUnload(), B.onLoad(), B.onShow() |
-
navigateTo , redirectTo 只能打开非 tabBar 页面。
-
switchTab 只能打开 tabBar 页面。
-
reLaunch 可以打开任意页面。
- 调用页面路由带的参数可以在目标页面的
onLoad 中获取。
|
请发表评论