简介

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

flutter系列之:在flutter中使用导航Navigator的更多相关文章

  1. flutter系列之:在flutter中使用流式布局

    目录 简介 Flow和FlowDelegate Flow的应用 总结 简介 我们在开发web应用的时候,有时候为了适应浏览器大小的调整,需要动态对页面的组件进行位置的调整.这时候就会用到flow la ...

  2. Flutter学习笔记(17)--顶部导航TabBar、TabBarView、DefaultTabController

    如需转载,请注明出处:Flutter学习笔记(17)--顶部导航TabBar.TabBarView.DefaultTabController 上一篇我们说了BottmNavigationBar底部导航 ...

  3. Flutter系列博文链接

    Flutter系列博文链接 ↓: Flutter基础篇: Flutter基础篇(1)-- 跨平台开发框架和工具集锦 Flutter基础篇(2)-- 老司机用一篇博客带你快速熟悉Dart语法 Flutt ...

  4. flutter系列之:用来管理复杂状态的State详解

    目录 简介 StatefuWidget和State State的生命周期 总结 简介 Flutter的基础是widget,根据是否需要跟用户进行交互,widget则可以分为StatelessWidge ...

  5. flutter页面间跳转和传参-Navigator的使用

    flutter页面间跳转和传参-Navigator的使用 概述 flutter中的默认导航分成两种,一种是命名的路由,一种是构建路由. 命名路由 这种路由需要一开始现在创建App的时候定义 new M ...

  6. 【Xamarin挖墙脚系列:多窗口之间的导航】

    原文:[Xamarin挖墙脚系列:多窗口之间的导航] 在Android中:Intent对象,通知松散耦合的Activity等组件 在IOS中:Segue对象连接视图 <button opaque ...

  7. 【JAVA零基础入门系列】Day5 Java中的运算符

    运算符,顾名思义就是用于运算的符号,比如最简单的+-*/,这些运算符可以用来进行数学运算,举个最简单的栗子: 已知长方形的长为3cm,高为4cm,求长方形的面积. 好,我们先新建一个项目,命名为Rec ...

  8. 【JAVA零基础入门系列】Day9 Java中的那个大数值

    什么是大数值?用脚趾头想也知道,当然是"大"的数值(233).Java中有两个用于表示大数值的类,BigInteger和BigDecimal,那到底能表示多大的数值呢?理论上,可以 ...

  9. 【JAVA零基础入门系列】Day10 Java中的数组

    什么是数组?顾名思义,就是数据的组合,把一些相同类型的数放到一组里去. 那为什么要用数组呢?比如需要统计全班同学的成绩的时候,如果给班上50个同学的成绩信息都命名一个变量进行存储,显然不方便,而且在做 ...

  10. 【JAVA零基础入门系列】Day11 Java中的类和对象

    今天要说的是Java中两个非常重要的概念--类和对象. 什么是类,什么又是对象呢?类是对特定集合的概括描述,比如,人,这个类,外观特征上,有名字,有年龄,能说话,能吃饭等等,这是我们作为人类的相同特征 ...

随机推荐

  1. 【DL论文精读笔记】 深度压缩

    深度压缩 DEEP COMPRESSION: COMPRESSING DEEP NEURAL NETWORKS WITH PRUNING, TRAINED QUANTIZATION AND HUFFM ...

  2. java环境改完版本后无效

    把C盘program files和X86两个文件夹中的Common Files中的Oracle文件夹删掉 这是jdk安装时自动生成的两个文件夹,记录了jdk的版本和路径,即使你的jdk安装路径不在C盘 ...

  3. MQ系列8:数据存储,消息队列的高可用保障

    MQ系列1:消息中间件执行原理 MQ系列2:消息中间件的技术选型 MQ系列3:RocketMQ 架构分析 MQ系列4:NameServer 原理解析 MQ系列5:RocketMQ消息的发送模式 MQ系 ...

  4. Visual Studio高版本 ArcObject for .Net 低版本

    在基于ArcGIS的开发中,经常会存在Visual Studio版本高,ArcObject for .Net 版本低的问题.例如Visual Studio 2015的环境下,安装ArcObject f ...

  5. 【实时数仓】Day03-DWM 层业务:各层的设计和常用信息、访客UV计算、跳出明细计算(CEP技术合并数据识别)、订单宽表(双流合并,事实表与维度数据合并)、支付宽表

    一.DWS层与DWM层的设计 1.设计思路 分流到了DWD层,并将数据分别出传入指定的topic 规划需要实时计算的指标,形成主题宽表,作为DWS层 2.需求梳理 DWM 层主要服务 DWS,因为部分 ...

  6. 关于Mybatis-Plus中update()、updateById()方法的使用及null值的判断

    使用场景说明: 在 Mybatis-Plus 的使用过程中,经常会遇对数据库更新的情况 更新常用方法:update().updateById() 问题:经常会遇见对 null 值的处理,对传入的实体参 ...

  7. C++面向对象程序设计期末复习笔记[吉林大学](结合历年题速成85)

    1.头文件 头文件的作用就是被其他的.cpp包含进去的.它们本身并不参与编译,但实际上,它们的内容却在多个.cpp文件中得到了编译.根据"定义只能一次"原则我们知道,头文件中不能放 ...

  8. 边框 display属性 盒子模型 浮动 溢出 定位 z-index

    目录 边框 隐藏属性 钓鱼网站 display visibility 盒子模型 调整方式 浮动 溢出 圆形头像的制作 定位 z-index属性 边框 /*border-left-width: 5px; ...

  9. Windows缓冲区溢出实验

    Windows缓冲区溢出 前言 windows缓冲区溢出学习笔记,大佬勿喷 缓冲区溢出 当缓冲区边界限制不严格时,由于变量传入畸形数据或程序运行错误,导致缓冲区被"撑暴",从而覆盖 ...

  10. JavaScript:变量:如何声明变量?

    声明变量可以用下面几种方式: 但是这几种声明方式肯定是有区别的,主要是上面三种方式的区别,这需要结合window对象和作用域来说明,这里不赘述. 声明变量的时候,推荐使用let,这是ES6新推出的更好 ...