Flutter 路由小谈
直接跳转
1 | import 'newpage.dart'; |
如果跳转的页面需要参数,可以直接传入。
初始化执行路线
定义路由集合
1 | final routes = { |
使用路由
1 | void main() { |
页面跳转
1 | Navigator.pushNamed(context, '/stats'); |
pushAndRemoveUntil
这个方式是跳转到某个页面,然后移除路由直到...
为止
1 | // 普通使用 |
上面的两种使用方式都可以达到禁止返回上一级的作用,应为这里给出的是 route == null
, 所以会将路由栈里的元素全部移除。
1 | Navigator.of(context).pushNamedAndRemoveUntil('/setting',ModalRoute.withName('/')); |
上面的方式可以在跳转到setting
页面后,若返回则直接到/
页面。
pushReplancementNamed
使用该方法跳转页面,会在路由栈中用新页面替换老页面。这时完成跳转后返回则好似返回上上个页面。
1 | Navigator.of(context).pushReplacementNamed('/page'); |
popUntil
1 | Navigator.popUntil(context,ModalRoute.withName('/')); |
与 pushAndRemoveUntil
配套,退回到某个指定页面。
popAndPushNamed
与pushReplacementNamed
方法类似,其执行结果栈是的路由栈与pushReplacementNamed
方法的效果是一致的。