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

相关文章

Go路由注册方法详解

《Go路由注册方法详解》Go语言中,http.NewServeMux()和http.HandleFunc()是两种不同的路由注册方式,前者创建独立的ServeMux实例,适合模块化和分层路由,灵活性高... 目录Go路由注册方法1. 路由注册的方式2. 路由器的独立性3. 灵活性4. 启动服务器的方式5.

本地搭建DeepSeek-R1、WebUI的完整过程及访问

《本地搭建DeepSeek-R1、WebUI的完整过程及访问》:本文主要介绍本地搭建DeepSeek-R1、WebUI的完整过程及访问的相关资料,DeepSeek-R1是一个开源的人工智能平台,主... 目录背景       搭建准备基础概念搭建过程访问对话测试总结背景       最近几年,人工智能技术

关于Gateway路由匹配规则解读

《关于Gateway路由匹配规则解读》本文详细介绍了SpringCloudGateway的路由匹配规则,包括基本概念、常用属性、实际应用以及注意事项,路由匹配规则决定了请求如何被转发到目标服务,是Ga... 目录Gateway路由匹配规则一、基本概念二、常用属性三、实际应用四、注意事项总结Gateway路由

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

四种Flutter子页面向父组件传递数据的方法介绍

《四种Flutter子页面向父组件传递数据的方法介绍》在Flutter中,如果父组件需要调用子组件的方法,可以通过常用的四种方式实现,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录方法 1:使用 GlobalKey 和 State 调用子组件方法方法 2:通过回调函数(Callb

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3