flutter 系列之: 在 flutter 中使用导航 Navigator
简介
一个 APP 如果没有页面跳转那么是没有灵魂的,页面跳转的一个常用说法就是 Navigator,flutter 作为一个最为优秀的前端框架,Navigator 肯定是必不可少的,那么在 flutter 中如何使用 Navigator 呢?
一起来看看吧。
flutter 中的 Navigator
Navigator 是 flutter 中用来导航的关键组件。我们先来看下 Navigator 的定义:
Navigator 首先是一个 StatefulWidget,为什么是一个有状态的 widget 呢?这是因为 Navigator 需要在内部报错一些路由的信息,事实上 Navigator 中保存的就是一个栈结构的历史访问过的 widget。
我们来看下它的构造函数,然后理解一下它内部的各个属性的含义:
在这些属性中 onGenerateRoute,pages,onGenerateInitialRoutes,transitionDelegate 和 observers 这几个参数必须是非 null。
首先是 pages,pages 是一个 List 对象:
这里的 pages 存储的就是历史访问信息,Navigator 的所有操作都是围绕着 pages 来的。
如果我们想在 page 切换的过程中添加一些动画,那么就可以用到 transitionDelegate,如果我们要弹出一些 page 的话,那么可能会希望用到 onPopPage callback 方法来对 pages list 进行一些特殊处理。
另外 initialRoute 是需要第一个展示的 route,Navigator 还提供了两个方法用来在生成 Route 的时候进行触发:onGenerateRoute,onGenerateInitialRoutes。
Navigator 提供了一系列的 pop 和 push 方法用来对路由进行跳转。
下面我们将会通过一个具体的例子来对 Navigator 进行详细的讲解。
Navigator 的使用
在这个例子中我们会使用 Navigator 的两个最基本的方法 push 和 pop 来进行路由的切换。
先来看下 push 方法的定义:
push 是一个静态方法,这意味着我们可以通过使用 Navigator.push 来进行调用。
push 方法需要传入两个参数,分别是 context 和 route。
为什么会有 context 呢?这是因为 Navigator 是和 context 相关联的,不同的 context 可以有不同的 Navigator。
Route 就是要导入的路由。
可以看到方法内部实际上是调用了 Navigator.of 方法,最后返回的是一个 Future 对象。
我们的例子是两个图片 widget 的简单切换。点击一个图像 widget 会调整到另外一个图像 widget 上,在另外一个图像 widget 上点击,会跳转回前一个 widget。
我们可以这样定义第一个 widget:
这里的 body 我们放置了一个 Image 对象,然后在它的点击 onTap 操作时,调用了 Navigator.push 方法。
因为 push 方法需要一个 Route 对象,这里我们使用了最简单的 MaterialPageRoute,然后返回第二个图像 widget 对象。
再来看看第二个图像 Widget 的定义:
和第一个图像 widget 一样,它的 body 也是一个 image,然后在点击 ontap 方法中跳回到第一个图片 widget 去。
这里的跳回方法使用的是 Navigator.pop,我们来看下 pop 方法的实现:
和 push 一样,pop 方法也接收一个 context 对象,但是它还有一个可选的 result 参数。最后实际调用的是 Navigator.of(context).pop 方法。
result 是做什么的呢?
还记得 push 方法吗?push 方法会返回一个 Future,也就是说 push 方法是有结果的,这个结果是从哪里来的呢?这个结果就是 pop 时候传进来的。
当我们调用 push 方法的时候,就会把这个 result 放在 Future 中返回。
运行上面的代码,首先我们得到第一个页面的 widget:
点击就会调整到第二个图片 widget:
再次点击就会跳回第一个页面,非常的神奇。
总结
Navigator 是每个 flutter app 都少不了的组件,希望大家能够掌握。
版权声明: 本文为 InfoQ 作者【程序那些事】的原创文章。
原文链接:【http://xie.infoq.cn/article/28c20b405003a0122bea06852】。文章转载请联系作者。
评论