flutter之从零开始搭建(二)之 Navigator路由

2024-08-24 07:48

本文主要是介绍flutter之从零开始搭建(二)之 Navigator路由,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • flutter之从零开始搭建(一)之 BottomNavigationBar

  • flutter之从零开始搭建(二)之 Navigator路由

  • flutter之从零开始搭建(二)之 网络请求

今天我们来讲讲利用Navigator来跳转页面的功能,承接上一篇flutter之从零开始搭建(一)之 BottomNavigationBar继续讲。

页面跳转是我们在入门学习的必备知识,在flutter中,路由跳转是由Navigator来操作的。

Navigator的跳转有两种,一种是显示跳转,需要我们在MaterialPageRoute中指定widget

  Navigator.of(context).push(new MaterialPageRoute(builder: (context) {//指定跳转的页面return new Demo1();},));

另一种是隐身跳转,这种跳转需要先定义,后使用,跳转方式就像Arouter一样的路径方式,定义部分需要在MaterialApp下定义routes,routes就跟一个Map<path,Page>集合一样,定义好了path对应的page,那么下次跳转,我们就可以针对path去跳转了

 @overrideWidget build(BuildContext context) {return new MaterialApp(home: new Scaffold(body: new Center(child: new RaisedButton(onPressed: _pushPage,child: new Text("跳转"))),),//定义路由routes: <String,WidgetBuilder>{"/demo1":(BuildContext context)=>new Demo1(),},);

跳转使用

 Navigator.of(context).pushNamed("/demo1");

知道路由如何跳转了,那么,我们开始实战吧

实战

我们看到,路由的跳转都带着一个context参数,这其中有无数的坑需要自己去理解,接下来我会展示出来。

还是承接上一篇博文flutter之从零开始搭建(一)之 BottomNavigationBar,我们先看下MyPage页面,先给出如下代码

import 'package:flutter/material.dart';
import 'package:codelang/widget/Demo1.dart';class MyPage extends StatelessWidget {@overrideWidget build(BuildContext context) {return new MaterialApp(theme: new ThemeData(primarySwatch: Colors.blue,),debugShowCheckedModeBanner: false,home: new PageWidget(),routes: <String,WidgetBuilder>{"/demo1":(BuildContext context)=>new Demo1(),},);}
}class PageWidget extends StatefulWidget {@overrideState<StatefulWidget> createState() {// TODO: implement createStatereturn new PageState();}
}class PageState extends State<PageWidget> {@overrideWidget build(BuildContext context) {return new Scaffold(body: new Center(child: new RaisedButton(onPressed: _pushPage,child: new Text("跳转"),),),);}_pushPage(){// Navigator.of(context).pushNamed("/demo1");Navigator.of(context).push(new MaterialPageRoute(builder: (context) {return new Demo1();},));}
}

大家整体看一下代码,其实没什么错误的地方,看起来一切都很正常,然后我们来看下效果图

image

what fuck!!! 跳转的页面怎么没有覆盖全屏,所以,这种方式肯定是不可取的。

我们先停下来想想,我们当前页面PageState是在PageWidget布局上面,PageWidget还有一个上层布局叫MyPage,我们是不是可以理解为,Navigator.of(context)的这个context指向的是上层MyPage布局的context,导致了页面路由跳转是在MyPage页面进行。

那么有什么解决办法呢?既然是context原因,那么,我们必须得拿到MyPage的上一层context,我们再想想,MyPage相当于一个fragment,是由MainPage页面组成的,我们只需要拿将MainPage页面的context传递给MyPage不就行了吗?接下来开干试试。

打开MainPage

给MyPage的构造方法传递MainPage的context

    _bodys = [new HomePage(),new ShopPage(),new MsgPage(),new MyPage(context)];

打开MyPage

MyPage拿到MainPage的parentContext,然后将parentContext传递给PageWidgetPageState可以通过widget.X的形式,可以拿到PageWidget的变量

import 'package:flutter/material.dart';
import 'package:codelang/widget/Demo1.dart';class MyPage extends StatelessWidget {var parentContext;MyPage(this.parentContext);@overrideWidget build(BuildContext context) {return new MaterialApp(title: 'Flutter Demo',theme: new ThemeData(primarySwatch: Colors.blue,),debugShowCheckedModeBanner: false,home: new PageWidget(parentContext),routes: <String,WidgetBuilder>{"/demo1":(BuildContext context)=>new Demo1(),},);}
}class PageWidget extends StatefulWidget {var parentContext;PageWidget(this.parentContext);@overrideState<StatefulWidget> createState() {// TODO: implement createStatereturn new PageState();}
}class PageState extends State<PageWidget> {@overrideWidget build(BuildContext context) {return new Scaffold(body: new Center(child: new RaisedButton(onPressed: _pushPage,child: new Text("跳转"),),),);}_pushPage(){
//    Navigator.of(widget.parentContext).pushNamed("/demo1");Navigator.of(widget.parentContext).push(new MaterialPageRoute(builder: (context) {return new Demo1();},));}
}

看下效果图

image

嗯,很完美的解决,大家有没有看到我_pushPage方法中注释了的pushNamed方式的跳转,大家猜猜,用这种方式会不会出错?5秒钟的思考哦.

  • 倒计时5s
  • 倒计时4s
  • 倒计时3s
  • 倒计时2s
  • 倒计时1s

OK,来揭晓答案,肯定是不行的,我们知道,routes的定义是在MyPage中的,而我们饿路由跳转拿到的parentContextMainPage的,所以,会报找不到这个路由的错误,如何解决呢?我相信到这大家应该都清楚了,那就是在MainPage中去定义这个routes,具体可以看如下

class MainPage extends StatelessWidget {@overrideWidget build(BuildContext context) {return new MaterialApp(debugShowCheckedModeBanner: false,routes: <String, WidgetBuilder>{"/demo1": (BuildContext context) => new Demo1(),},home: new MainPageWidget());}
}

这样跳转就可以了,效果图我就不贴出来了,跟上面一样。


你以为就这样结束了?哈哈,早着呢,在写这篇博文的时候,我又发现了一个好玩的地方,为了区分,我在HomePage页面去写这个例子,代码不多,大家看看

HomePage

import 'package:flutter/material.dart';
import 'package:codelang/widget/Demo1.dart';class HomePage extends StatefulWidget {@overrideState<StatefulWidget> createState() {// TODO: implement createStatereturn new HomeState();}
}class HomeState extends State<HomePage> {@overrideWidget build(BuildContext context) {// TODO: implement buildreturn new MaterialApp(debugShowCheckedModeBanner: false,home: new Scaffold(body: new Center(child: new RaisedButton(onPressed: _pushPage,child: new Text("跳转"))),),);}_pushPage() {
//    Navigator.of(context).pushNamed("/demo1");Navigator.of(context).push(new MaterialPageRoute(builder: (context) {return new Demo1();},));}
}

在这个路由跳转中,我用了context来跳转,大家再猜猜,这种方式可以嘛?5秒钟的思考时间

  • 倒计时5s
  • 倒计时4s
  • 倒计时3s
  • 倒计时2s
  • 倒计时1s

答案揭晓,是可以的哦,为什么这样又可以了呢?

HomePageMyPage的区别在于定义这个widget时,MyPage最外套的一层是StatelessWidget,而HomePage最外套的一层是StatefulWidgetStatelessWidget是一个无状态的widget,难道是他阻隔了context的传递?具体的我也不清楚,只能去猜。

大家再猜猜还是那段注释了的pushNamed的代码,可不可以跳转呢?哈哈,当然是可以的,因为我们在前面的时候,就已经在mainPage中定义了routes


好了,路由这篇说完了,唯一坑就是context的问题,看了这一篇,相信很多人都理解了Navigator如何跳转,下一篇再见吧

gayhub链接

这篇关于flutter之从零开始搭建(二)之 Navigator路由的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1101880

相关文章

如何使用Haporxy搭建Web群集

《如何使用Haporxy搭建Web群集》Haproxy是目前比较流行的一种群集调度工具,同类群集调度工具有很多如LVS和Nginx,本案例介绍使用Haproxy及Nginx搭建一套Web群集,感兴趣的... 目录一、案例分析1.案例概述2.案例前置知识点2.1 HTTP请求2.2 负载均衡常用调度算法 2.

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

如何搭建并配置HTTPD文件服务及访问权限控制

《如何搭建并配置HTTPD文件服务及访问权限控制》:本文主要介绍如何搭建并配置HTTPD文件服务及访问权限控制的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、安装HTTPD服务二、HTTPD服务目录结构三、配置修改四、服务启动五、基于用户访问权限控制六、

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

Windows Server 2025 搭建NPS-Radius服务器的步骤

《WindowsServer2025搭建NPS-Radius服务器的步骤》本文主要介绍了通过微软的NPS角色实现一个Radius服务器,身份验证和证书使用微软ADCS、ADDS,具有一定的参考价... 目录简介示意图什么是 802.1X?核心作用802.1X的组成角色工作流程简述802.1X常见应用802.

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1

Spring Cloud GateWay搭建全过程

《SpringCloudGateWay搭建全过程》:本文主要介绍SpringCloudGateWay搭建全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Spring Cloud GateWay搭建1.搭建注册中心1.1添加依赖1.2 配置文件及启动类1.3 测

Nginx路由匹配规则及优先级详解

《Nginx路由匹配规则及优先级详解》Nginx作为一个高性能的Web服务器和反向代理服务器,广泛用于负载均衡、请求转发等场景,在配置Nginx时,路由匹配规则是非常重要的概念,本文将详细介绍Ngin... 目录引言一、 Nginx的路由匹配规则概述二、 Nginx的路由匹配规则类型2.1 精确匹配(=)2