热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

(十一)Flutter表单验证与提交。Theme的定制使用重置,TextField文本字段。

修改main.dartimportpackage:fluttermaterial.dart;importpackage:nihao_flutterdemoform_demo.d

修改main.dart

import 'package:flutter/material.dart';
import 'package:nihao_flutter/demo/form_demo.dart';
import 'package:nihao_flutter/demo/navigator_demo.dart';
import 'package:nihao_flutter/demo/home_demo.dart';void main() => runApp(MyApp());class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) { // TODO: implement buildreturn MaterialApp(debugShowCheckedModeBanner: false,// home: NavigatorDemo(),initialRoute: '/form',routes: {'/':(context)=>HomeDemo(), '/form':(context)=>FormDemo(), },theme: ThemeData(primarySwatch: Colors.yellow,highlightColor: Color.fromRGBO(255, 255, 255, 0.5),splashColor: Colors.red),);}
}

新建form_demo.dart

import 'package:flutter/material.dart';class FormDemo extends StatelessWidget {@overrideWidget build(BuildContext context) {return Scaffold(body: Theme(data: Theme.of(context).copyWith(primaryColor: Colors.black,),child: Container(padding: EdgeInsets.all(16.0),child: Column(mainAxisAlignment: MainAxisAlignment.center,children: [RegisterForm(),],),),),);}
}class RegisterForm extends StatefulWidget {@overrideRegisterFormState createState() => RegisterFormState();
}class RegisterFormState extends State {final registerFormKey = GlobalKey();String username, password;bool _autovalidate=false;void submintRegisterForm() {if(registerFormKey.currentState.validate()){registerFormKey.currentState.save();debugPrint('username $username');debugPrint('password $password');Scaffold.of(context).showSnackBar(SnackBar(content: Text('Registering...'),));}else{setState(() {_autovalidate=true;});}}String validateUsername(value) {if (value.isEmpty) {return "Username os required.";}return null;}String validatePassword(value) {if (value.isEmpty) {return "Password is required.";}return null;}@overrideWidget build(BuildContext context) {return Form(key: registerFormKey,child: Column(children: [TextFormField(decoration: InputDecoration(labelText: 'Username',helperText: 'please input Username',),onSaved: (value) {username = value;},validator: validateUsername,autovalidate: _autovalidate,),TextFormField(obscureText: true,decoration: InputDecoration(labelText: 'Password',helperText: 'please inputPassword',),onSaved: (value) {password = value;},validator: validatePassword,autovalidate: _autovalidate,),SizedBox(height: 32.0,),Container(width: double.infinity,child: RaisedButton(color: Colors.green,child: Text('Register', style: TextStyle(color: Colors.white)),elevation: 0.0,onPressed: submintRegisterForm,),),],),);}
}class ThemeDemo extends StatelessWidget {@overrideWidget build(BuildContext context) {return Container(color: Theme.of(context).splashColor,);}
}class TextFieldDemo extends StatefulWidget {@overrideState createState() {// TODO: implement createStatereturn TextFieldDemoState();}
}class TextFieldDemoState extends State {final textEditingController = TextEditingController();@overridevoid dispose() {textEditingController.dispose();super.dispose();}@overridevoid initState() {super.initState();// textEditingController.text='hi';textEditingController.addListener(() {debugPrint('input ${textEditingController.text}');});}@overrideWidget build(BuildContext context) {// TODO: implement buildreturn TextField(controller: textEditingController,// onChanged: (value){// debugPrint('input:$value');// },onSubmitted: (value) {debugPrint('submit:$value');},decoration: InputDecoration(icon: Icon(Icons.subject),labelText: 'Title',hintText: 'Enter the post title.',// border: InputBorder.none,// border: OutlineInputBorder(),filled: true,fillColor: Colors.green),);}
}

vscode f5运行看效果

android studio shift+f10

 


推荐阅读
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 本文介绍了Java中Hashtable的clear()方法,该方法用于清除和移除指定Hashtable中的所有键。通过示例程序演示了clear()方法的使用。 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 本文整理了Java面试中常见的问题及相关概念的解析,包括HashMap中为什么重写equals还要重写hashcode、map的分类和常见情况、final关键字的用法、Synchronized和lock的区别、volatile的介绍、Syncronized锁的作用、构造函数和构造函数重载的概念、方法覆盖和方法重载的区别、反射获取和设置对象私有字段的值的方法、通过反射创建对象的方式以及内部类的详解。 ... [详细]
  • SmartRefreshLayout自定义头部刷新和底部加载
    1.添加依赖implementation‘com.scwang.smartrefresh:SmartRefreshLayout:1.0.3’implementation‘com.s ... [详细]
author-avatar
搜狐搜不到你的爱_276
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有