简介

一个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