4.1 表单属性代码
//变量定义
var userNameController = new TextEditingController();
var passWordController = new TextEditingController();
var _userNameFieldValue = ‘’;
var _passWordFieldValue = ‘’;
var _name = ‘’;
var _pwd = ‘’;
final _formKey = GlobalKey();
//body部分
body: Form(
key: _formKey,
onWillPop: () async {
return await showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: Text(‘提示’),
content: Text(‘确认退出吗?’),
actions: [
FlatButton(
child: Text(‘取消’),
onPressed: () {
Navigator.of(context).pop(false);
},
),
FlatButton(
child: Text(‘确认’),
onPressed: () {
Navigator.of(context).pop(true);
},
),
],
);
});
},
//autovalidateMode:AutovalidateMode.disabled ,
child: Column(
children: [
Text(
“用户名”,
style: TextStyle(
color: Colors.black,
fontSize: 16,
fontWeight: FontWeight.bold),
),
TextFormField(
controller: userNameController,
decoration: InputDecoration(
icon: Icon(Icons.person),
suffixIcon: Icon(Icons.delete),
labelText: “请输入用户名”,
counterText: “${_userNameFieldValue.length}/32”),
autovalidateMode: AutovalidateMode.disabled,
validator: (userName) {
if (userName.length < 3) {
return “用户名过短”;
}
return null;
},
onChanged: (value) {
setState(() {
_userNameFieldValue = value;
});
},
onSaved: (value) {
_name = value;
},
keyboardType: TextInputType.number,
textCapitalization: TextCapitalization.words,
textInputAction: TextInputAction.search,
),
Text(“密码”,
style: TextStyle(
color: Colors.black,
fontSize: 16,
fontWeight: FontWeight.bold)),
TextFormField(
controller: passWordController,
decoration: InputDecoration(
icon: Icon(Icons.lock),
suffixIcon: Icon(Icons.delete),
labelText: “请输入密码”,
counterText: “${_passWordFieldValue.length}/32”,
),
autovalidateMode: AutovalidateMode.disabled,
obscureText: true,
validator: (passWord) {
if (passWord.length < 3) {
return “密码过短”;
}
return null;
},
onChanged: (value) {
setState(() {
_passWordFieldValue = value;
});
},
onSaved: (value) {
_pwd = value;
},
),
RaisedButton(
onPressed: () {
var _state = _formKey.currentState;
if (_state.validate()) {
_state.save();
login(_name, _pwd);
}
//login(_userNameFieldValue, _passWordFieldValue);
},
child: Text(“登录”),
)
],
),
onChanged: () {
//print(“用户名:${userNameController.text}”);
//print(“密码:${passWordController.text}”);
},
));
//login方法
void login(String name, String pwd)
{
print(“用户名: n a m e , 密码: name,密码: name,密码:_pwd”);
userNameController.clear();
passWordController.clear();
}
4.2 效果图
4.3 Form属性
| 属性 | 说明 | 取值 |
| :-: | :-: | :-: |
| key | 整个应用程序中唯一的密钥 | Key对象 |
| onWillPop | 返回按钮拦截后的小控件的方法 | WillPopCallback对象 |
| autovalidateMode | 输入框变化校验 | bool对象 |
| onChanged | 输入框发生变化时的回调函数 | Function对象 |
4.4 TextFormField
| 属性 | 说明 | 取值 |
| :-: | :-: | :-: |
| initialValue | 初始值 | String对象 |
| keyboardType① | 键盘类型 | TextInputType对象 |
| textCapitalization② | 文本的断行方式 | TextCapitalization枚举值 |
| textInputAction③ | 键盘输入按钮的类型 | TextInputAction枚举值 |
| decoration④ | 输入框试图 | InputDecoration对象 |
| style | 文本风格 | TextStyle对象 |
| textDirection | 文本方向 | TextDirection枚举值 |
| textAlign | 文本对齐方式 | TextAlign枚举值 |
| obscureText | 文本显示是否加密 | bool对象 |
| autocorrect | 是否开启自动更正 | bool对象 |
| autovalidate | 是否自动有效性检查 | bool对象 |
| maxLines | 最大行数 | int对象 |
| onEditingComplete | 编辑完成时的回调 | Function |
| onFieldSubmitted | 表单提交时的回调 | Function |
| onSaved | 表单保存时的回调 | Function |
| validator | 有效性校验函数 | Function |
| enabled | 输入框是否可用 | bool对象 |
keyboardType①
| 名称 | 说明 |
| :-: | :-: |
| datetime | 日期时间类型 |
| emailAddress | Email地址类型 |
| multiline | 多行文本类型 |
| number | 数字键盘类型 |
| phone | 电话类型 |
| text | 文本类型 |
| url | 网址链接类型 |
textCapitalization②
| 名称 | 说明 |
| :-: | :-: |
| characters | 使用字符进行断行 |
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)
文末
很多人在刚接触这个行业的时候或者是在遇到瓶颈期的时候,总会遇到一些问题,比如学了一段时间感觉没有方向感,不知道该从那里入手去学习,对此我整理了一些资料,需要的可以免费分享给大家
这里笔者分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。
【视频教程】
天道酬勤,只要你想,大厂offer并不是遥不可及!希望本篇文章能为你带来帮助,如果有问题,请在评论区留言。
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。
[外链图片转存中…(img-vHIsIlYe-1712514726026)]
[外链图片转存中…(img-2ld1erva-1712514726026)]
【视频教程】
[外链图片转存中…(img-jG4fp1Zo-1712514726026)]
天道酬勤,只要你想,大厂offer并不是遥不可及!希望本篇文章能为你带来帮助,如果有问题,请在评论区留言。
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!