Flutter学习二——登录成功后跳转主界面
时间:2019-11-03
本文章向大家介绍Flutter学习二——登录成功后跳转主界面,主要包括Flutter学习二——登录成功后跳转主界面使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
在上一篇我已经写了个登录的主界面,这一篇登录的界面和上一篇的差别就只是将_login()方法的写法给改变了
上一篇 FLutter的登录界面传送门
因为登录成功之后我们需要跳转到主界面,所以需要用到路由
代码
bool _login() { if (_userName.text == "admin" && _userPws.text == "123456") { return true; } else { showDialog( context: context, builder: (context) { return AlertDialog( title: Text("提示"), content: Text("账号或密码错误,请检查"), actions: <Widget>[ FlatButton( child: Text("确认"), onPressed: () { Navigator.of(context).pop(true); //关闭对话框 }, ) ], ); }); return false; } }
我们再来看看上一篇是怎么写的
可以看到,上一篇用的是 void 这一次用的是bool,之所以用bool的原因是因为我们需要判断用户名密码是否正确,这时候就需要判断true和false,
用void就没法判断,强行跳转就会报错。
再来看看登录按钮的登录事件代码
onPressed: () { if ((_keyFrom.currentState as FormState).validate()) { if (_login() == true) { Navigator.of(context).pushAndRemoveUntil( new MaterialPageRoute( builder: (context) => new IndexPage()), (route) => route == null); } } },
这段代码也很简单,就是先判断输入框是否输入正确,和上一篇一样,然后在判断登录状态是否为true,
如果为true则跳转到IndexPage的这个界面去,跳转过去后清空路由,使用户无法使用返回键返回登录状态。
indexPage的代码,就是实现一个底部的导航栏
import 'package:flutter/material.dart'; import 'package:newlogin/firstPage.dart'; import 'package:newlogin/secondPage.dart'; import 'package:newlogin/thirdPage.dart'; class IndexPage extends StatefulWidget { @override State<StatefulWidget> createState() => IndexPageState(); } class IndexPageState extends State<IndexPage> { int _tabIndex=0; List<BottomNavigationBarItem> _navigationView; var appBarTitles=['首页','发现','我的']; PageController pageController; var _body; // 初始化几个底部item initData(){ _body=new IndexedStack( children: <Widget>[ new FirstPage(),new SecondPage(),new ThirdPage() ], index: _tabIndex, ); } @override void initState(){ super.initState(); _navigationView=<BottomNavigationBarItem>[ new BottomNavigationBarItem( icon: const Icon(Icons.home), title: new Text(appBarTitles[0]), backgroundColor: Colors.blue ), new BottomNavigationBarItem( icon: const Icon(Icons.widgets), title:new Text(appBarTitles[1]), backgroundColor: Colors.blue ), new BottomNavigationBarItem( icon: const Icon(Icons.person), title: new Text(appBarTitles[2]) ), ]; } final navigatorKey=GlobalKey<NavigatorState>(); @override Widget build(BuildContext context) { initData(); return new MaterialApp( navigatorKey: navigatorKey, theme: new ThemeData( primaryColor: Colors.blue, accentColor: Colors.blue, ), home: new Scaffold( appBar: new AppBar( title: new Text( appBarTitles[_tabIndex], style: new TextStyle(color: Colors.white), ), ), body: _body, bottomNavigationBar: new BottomNavigationBar( items: _navigationView .map((BottomNavigationBarItem navigationView)=>navigationView) .toList(), currentIndex: _tabIndex, type: BottomNavigationBarType.fixed, onTap: (index) { setState(() { _tabIndex = index; }); }, ), ), ); } }
firstPage.dart代码,其他两个也一样,就不一一上代码了
import 'package:flutter/material.dart'; class FirstPage extends StatefulWidget { @override State<StatefulWidget> createState() => new FirstPageState(); } class FirstPageState extends State<FirstPage> { @override Widget build(BuildContext context) { return new Scaffold( body: new Center( child: new Text('这是第一个界面'), ), ); } }
如果上面的比较慢可以用下面的 Gitee传送门
原文地址:https://www.cnblogs.com/inthecloud/p/11785826.html
- re模块(正则表达式)
- Python学习——collections系列
- 为stackGan一个工程创建一个虚拟环境,python 2.7 tensorflow0.12-tensorflow 1.01
- linux 普通操作,查看资源使用情况
- Python 函数使用记录,join函数和os.path.join用法
- 01.SQLServer性能优化之----强大的文件组----分盘存储
- stackGan实验
- pyTorch基础入门练习
- 昨天遇到的几个常用函数
- 【深入浅出】一篇超棒的机器学习入门文章
- .NET中的异步编程上
- 从python2到python3
- 【干货】如何写代码 -编程内功心法
- .NET中的异步编程下
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 模仿echo命令学习NIO——Java实现
- Java 7 种阻塞队列详解
- protocol buffers 序列化数据
- dubbo的Failed to save registry store file问题
- TDSQL 安装部署(多图预警)
- Table has no partition for value 20190507
- Greenplum 对JSON的支持(最新版)
- iOS 音视频接入-音视频基础
- PHP的bz2压缩扩展工具
- PHP的命令行扩展Readline相关函数学习
- Goland中使用Golang命令行工具
- MHA搭建之ssh互信打通脚本
- pt-slave-restart工具
- 二叉树:层序遍历登场!
- 二叉树:前中后序迭代方式的写法就不能统一一下么?