文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么在Flutter中使用导航Navigator

2023-07-05 04:49

关注

本篇内容主要讲解“怎么在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(          'https://file.lsjlt.com/upload/202307/04/wnzv0qvraqg.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中返回。

到此,相信大家对“怎么在Flutter中使用导航Navigator”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯