共计 3106 个字符,预计需要花费 8 分钟才能阅读完成。
简介
一个 APP 如果没有页面跳转那么是没有灵魂的,页面跳转的一个罕用说法就是 Navigator,flutter 作为一个最为优良的前端框架,Navigator 必定是必不可少的,那么在 flutter 中如何应用 Navigator 呢?
一起来看看吧。
flutter 中的 Navigator
Navigator 是 flutter 中用来导航的要害组件。咱们先来看下 Navigator 的定义:
class Navigator extends StatefulWidget
Navigator 首先是一个 StatefulWidget,为什么是一个有状态的 widget 呢?这是因为 Navigator 须要在外部报错一些路由的信息,事实上 Navigator 中保留的就是一个栈构造的历史拜访过的 widget。
咱们来看下它的构造函数,而后了解一下它外部的各个属性的含意:
const Navigator({
Key? key,
this.pages = const <Page<dynamic>>[],
this.onPopPage,
this.initialRoute,
this.onGenerateInitialRoutes = Navigator.defaultGenerateInitialRoutes,
this.onGenerateRoute,
this.onUnknownRoute,
this.transitionDelegate = const DefaultTransitionDelegate<dynamic>(),
this.reportsRouteUpdateToEngine = false,
this.observers = const <NavigatorObserver>[],
this.restorationScopeId,
})
在这些属性中 onGenerateRoute,pages,onGenerateInitialRoutes,transitionDelegate 和 observers 这几个参数必须是非 null。
首先是 pages,pages 是一个 List 对象:
final List<Page<dynamic>> pages;
这里的 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 办法的定义:
static Future<T?> push<T extends Object?>(BuildContext context, Route<T> route) {return Navigator.of(context).push(route);
}
push 是一个静态方法,这意味着咱们能够通过应用 Navigator.push 来进行调用。
push 办法须要传入两个参数,别离是 context 和 route。
为什么会有 context 呢?这是因为 Navigator 是和 context 相关联的,不同的 context 能够有不同的 Navigator。
Route 就是要导入的路由。
能够看到办法外部实际上是调用了 Navigator.of 办法,最初返回的是一个 Future 对象。
咱们的例子是两个图片 widget 的简略切换。点击一个图像 widget 会调整到另外一个图像 widget 上,在另外一个图像 widget 上点击,会跳转回前一个 widget。
咱们能够这样定义第一个 widget:
class FirstPage extends StatelessWidget {const FirstPage({Key? key}) : super(key: key);
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('First Page'),
),
body: GestureDetector(onTap: () {Navigator.push(context, MaterialPageRoute(builder: (context) {return const SecondPage();
}));
},
child: Image.network('http://www.flydean.com/wp-content/uploads/2019/06/cropped-head5.jpg',),
),
);
}
这里的 body 咱们搁置了一个 Image 对象,而后在它的点击 onTap 操作时,调用了 Navigator.push 办法。
因为 push 办法须要一个 Route 对象,这里咱们应用了最简略的 MaterialPageRoute,而后返回第二个图像 widget 对象。
再来看看第二个图像 Widget 的定义:
class SecondPage extends StatelessWidget {const SecondPage({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
body: GestureDetector(onTap: () {Navigator.pop(context);
},
child: Center(
child: Image.network('https://img-blog.csdnimg.cn/bb5b19255ab6406cb6bdc467ecc40462.webp',),
),
),
);
}
}
和第一个图像 widget 一样,它的 body 也是一个 image, 而后在点击 ontap 办法中跳回到第一个图片 widget 去。
这里的跳回办法应用的是 Navigator.pop,咱们来看下 pop 办法的实现:
static void pop<T extends Object?>(BuildContext context, [ T? result]) {Navigator.of(context).pop<T>(result);
}
和 push 一样,pop 办法也接管一个 context 对象,然而它还有一个可选的 result 参数。最初理论调用的是 Navigator.of(context).pop 办法。
result 是做什么的呢?
还记得 push 办法吗?push 办法会返回一个 Future,也就是说 push 办法是有后果的,这个后果是从哪里来的呢?这个后果就是 pop 时候传进来的。
当咱们调用 push 办法的时候,就会把这个 result 放在 Future 中返回。
运行下面的代码,首先咱们失去第一个页面的 widget:
点击就会调整到第二个图片 widget:
再次点击就会跳回第一个页面,十分的神奇。
总结
Navigator 是每个 flutter app 都少不了的组件,心愿大家可能把握。
本文的例子:https://github.com/ddean2009/learn-flutter.git