🚀 优质资源分享 🚀
学习路线指引(点击解锁) | 知识定位 | 人群定位 |
---|---|---|
🧡 Python实战微信订餐小程序 🧡 | 进阶级 | 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。 |
💛Python量化交易实战💛 | 入门级 | 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统 |
Android multiple back stacks导航
谈谈android中多栈导航的几种实现.
什么是multiple stacks
当用户在app里切换页面时, 会需要向后回退到上一个页面, 页面历史被保存在一个栈里.
在Android里我们经常说"back stack".
有时候在app里我们需要维护多个back stack, 比较典型的场景是bottom navigation bar或者侧边的drawer.
如果需求要求在切换tab的时候保存每个tab上的历史, 这样当用户返回的时候还是返回到上次离开的地方, 这种就叫multiple stacks.
(与之对应的single stack行为是返回之后回到了tab首页.)
本文之后的内容都以bottom bar的多栈导航为例.
multi-stack的需求
首先还是讨论一下需求.
当bottom bar不支持多栈时, 当点击切换底部tab, 再返回原来的tab, 所有在之上打开的页面都会消失, 只有第一层(根)页面会显示.
这也是可以接受的, 甚至在material design里面作为Android平台的默认行为被提及: material design
但它同时也说了, 如果需要的话, 这个行为是可以被改的.
如果你想保留用户在上个tab看过的内容状态, 很可能就需要做multi-stack, 每个tab上的栈是独立退出, 分别保留的.
通常, 这还不是仅有的需求.
如果用户点击已选中的tab, 需要重置这个stack吗?
需要定制转场动画吗?
需要保留tab历史吗? 比如从tab A -> B -> C, 在C的根页面back, 是想回到B还是回到home tab?
在bottom navigation的默认实现中(用Android Studio创建一个Bottom Navigation的新项目), 在非home tab的根节点, 点击back, 总是先回到home tab, 再次back才会退出app.
因为这样是符合固定start destination的原则的. 用户在打开后和关闭前, 看到的是同一个页面.
但是如果你有保存tab历史的需求, 也可以考虑如何定制它.
当你更进一步地涉及到实现层面, 你会遇到更多实际操作的问题, 比如怎么把一个详情页push到一个指定的栈, 如何pop destination.
让我们列一下几个需求点:
- 维护多个栈.
- 切换tab: 手动点击tab或者其他tab内的交互. 比如dashboard跳转到某个内