flutter系列之:在flutter中使用导航Navigator

简介: 一个APP如果没有页面跳转那么是没有灵魂的,页面跳转的一个常用说法就是Navigator,flutter作为一个最为优秀的前端框架,Navigator肯定是必不可少的,那么在flutter中如何使用Navigator呢?一起来看看吧。

简介

一个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://ucc.alicdn.com/images/user-upload-01/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

相关文章
|
12月前
|
UED 索引
Flutter仿写微信导航栏快速实现页面导航
Flutter仿写微信导航栏快速实现页面导航
|
存储 Android开发 iOS开发
flutter系列之:Navigator的高级用法
上篇文章我们讲到了flutter中navigator的基本用法,我们可以使用它的push和pop方法来进行Router之间的跳转。 在flutter中一个Router就是一个widget,但是在Android中,一个Router就是Activity,在IOS中,一个Router是一个ViewController。 Router除了之前讲过的push和pop方法之外,还有一些更加高级的用法,一起来看看吧。
flutter系列之:Navigator的高级用法
|
Android开发 iOS开发
flutter 路由管理- Navigator的push和pop
Navigator类是flutter一个路由管理的组件,通过一个栈来管理活动路由集合,通常当前屏幕显示的页面就是栈顶的路由。
1008 0
|
API Android开发 开发者
Flutter入门-路由导航
首先什么是路由,路由对于移动开发者来说就是页面,比如对于我们Android开发者来说就是 Activity A-> ActivityB,类似ios中的 ViewController。
162 0
|
Android开发 开发者
Flutter教程 — 路由管理与Navigator进阶使用(老油条看了都说好!!!)
在上一节我们已经讲了Flutter路由管理与Navigator基础使用,有兴趣或者对这一块还不太了解的同学可以去看看。 但是仅仅这样时不够的 在实际项目中这些怎么会够呢???现在让我们来看看这些骚操作…
Flutter教程 — 路由管理与Navigator进阶使用(老油条看了都说好!!!)
|
前端开发 程序员
Flutter路由管理与Navigator基础使用
Flutter的路由管理与Navigator基础使用
Flutter路由管理与Navigator基础使用
|
ARouter
flutter之从零开始搭建(二)之 Navigator路由
flutter之从零开始搭建(二)之 Navigator路由
186 0
flutter之从零开始搭建(二)之 Navigator路由
|
前端开发 Android开发 iOS开发
Flutter路由导航Flutter路由导航
我们通常会用屏(Screen)来称呼一个页面(Page),一个完整的App应该是有多个Page组成的。 在之前的案例(豆瓣)中,我们通过IndexedStack来管理了首页中的Page切换: 首页-书影音-小组-市集-我的 通过点击BottomNavigationBarItem来设置IndexedStack的index属性来切换 除了上面这种管理页面的方式,我们还需要实现其它功能的页面跳转:比如点击一个商品跳转到详情页,某个按钮跳转到发送朋友圈、微博的编辑页面。 这种页面的管理和导航,我们通常会使用路由进行统一管理。
224 0
Flutter路由导航Flutter路由导航
|
前端开发 Android开发 iOS开发
Day13 - Flutter - 路由导航
Day13 - Flutter - 路由导航
168 0
Day13 - Flutter - 路由导航
|
定位技术 iOS开发
Flutter怎么实现地图导航功能?
引子 一个app 咋能没有导航功能呢,我们在应用开发中经常需要用到地图定位或导航的功能,而集成该功能的方式总的来说分为两类:
578 0