Flutter组件学习(三)—— 输入框TextFiled

简介:

序言
Google 前两天发布了 Flutter 1.0 正式版本,正式版发布之后,LZ身边越来越多的人都开始入坑了,不得不说 Flutter 框架的魅力还是很吸引人的哈,所以我们更要抓紧学习了;之前我写了两篇文章来介绍 Flutter中的Text组件 和 Flutter中的Image组件,今天我们继续学习输入框 TextFiled 组件,话不多说,先上图:
image
TextFiled组件的API
先来看一下TextFiled的构造方法:

 1const TextField({
 2  Key key,
 3  this.controller,
 4  this.focusNode,
 5  this.decoration = const InputDecoration(),
 6  TextInputType keyboardType,
 7  this.textInputAction,
 8  this.textCapitalization = TextCapitalization.none,
 9  this.style,
10  this.textAlign = TextAlign.start,   //类似Text组件
11  this.textDirection,   //类似Text组件
12  this.autofocus = false,
13  this.obscureText = false,
14  this.autocorrect = true,
15  this.maxLines = 1,
16  this.maxLength,
17  this.maxLengthEnforced = true,
18  this.onChanged,
19  this.onEditingComplete,
20  this.onSubmitted,
21  this.inputFormatters,
22  this.enabled,
23  this.cursorWidth = 2.0,
24  this.cursorRadius,
25  this.cursorColor,
26  this.keyboardAppearance,
27  this.scrollPadding = const EdgeInsets.all(20.0),
28  this.enableInteractiveSelection = true,
29  this.onTap,
30})

哇,乍一看好多配置啊,别急大兄弟,有很多我们在讲 Text 组件的时候已经讲过的,接下来我们一个一个来看这些属性:

1、controller

根据字面意思我们就可以知道,这是一个控制器,毫无疑问当然是控制 TextField 组件的了,用处有很多,可以监听输入框的输入(通过controller.addListener()),可以获取输入框的值,可以设置输入框的值等等。

 1TextEditingController _textEditingController = new TextEditingController();
 2
 3new TextField(
 4  controller: _textEditingController,
 5),
 6new RaisedButton(
 7  onPressed: () {
 8    print(_textEditingController.text);
 9    _textEditingController.clear();
10  },
11  child: Text('清除'),
12)

2、focusNode

这个属性可以用来监听输入框是否获取(失去)焦点:

 1FocusNode _focusNode = new FocusNode();
 2
 3@override
 4void initState() {
 5  super.initState();
 6  _focusNode.addListener(_focusNodeListener);
 7}
 8
 9Future<Null> _focusNodeListener() async {
10  if (_focusNode.hasFocus) {
11    print('获取焦点');
12  } else {
13    print('失去焦点');
14  }
15}
16
17new TextField(
18  focusNode: _focusNode,
19)

3、decoration

这个属性用来设置输入框的一些样式,比如前后图标,提示文字,错误文字,占位文字等等,下面来看一下可以设置的东西(有点多,大家可以有需要的时候再去挨个了解):

 1const InputDecoration({
 2  this.icon,  //输入框前面的图片(在下划线外面)
 3  this.labelText,  //顶部提示文字(获取焦点之后会移动到输入框上方)
 4  this.labelStyle,
 5  this.helperText,  //底部提示文字(不会移动)
 6  this.helperStyle,
 7  this.hintText,  //占位文字
 8  this.hintStyle,
 9  this.errorText,  //类似helperText
10  this.errorStyle,
11  this.errorMaxLines,
12  this.hasFloatingPlaceholder = true,
13  this.isDense,
14  this.contentPadding,  //输入内容的边距,默认有一个边距,可以手动设置
15  this.prefixIcon, //输入框前面的图片(在下划线里面)
16  this.prefix,
17  this.prefixText,
18  this.prefixStyle,
19  this.suffixIcon,  //输入框后面的图片(在下划线里面)
20  this.suffix,
21  this.suffixText,
22  this.suffixStyle,
23  this.counterText,
24  this.counterStyle,
25  this.filled,
26  this.fillColor,
27  this.errorBorder,
28  this.focusedBorder,
29  this.focusedErrorBorder,
30  this.disabledBorder,
31  this.enabledBorder,
32  this.border,   //输入框边框线(默认是下划线,也可以是none,也可以是一个框)
33  this.enabled = true,
34  this.semanticCounterText,
35})
 1new TextField(
 2  decoration: InputDecoration(
 3    labelText: '请输入手机号',
 4    //设置输入框前面有一个电话的按钮 suffixIcon
 5    prefixIcon: Icon(Icons.phone),
 6    labelStyle: TextStyle(
 7      fontSize: 14,
 8      color: Colors.grey,
 9    ),
10  ),
11)

4、keyboardType

这个属性是设置输入框的输入类型的,类似于 Android 中的 InputType,选值有以下几个:

text 输入文字

multiline 输入文字

number 输入文字

phone 输入文字

datetime 输入文字

emailAddress 输入文字

url

1new TextField(
2  keyboardType: TextInputType.number,
3)

5、obscureText

这个属性用来控制显示隐藏用户输入的内容(密文/明文显示)。

6、textInputAction

这个属性用来控制弹出的键盘中右下角的按钮,这是一个枚举值,有很多种形式(下面举几个例子):

TextInputAction.done:完成按钮

TextInputAction.go:根据用户输入进行下一步按钮

TextInputAction.newline:换行按钮

TextInputAction.next:下一步按钮

TextInputAction.previous:上一步按钮

TextInputAction.search:搜索按钮

TextInputAction.send:发送按钮

大家可以手动试试各个枚举值的效果。

7、TextCapitalization

这个属性用来控制输入内容的大小写设置,同样是一个枚举值,来看一下具体的值及效果:

TextCapitalization.words:输入的每个单词的首字母大写(用空格隔开的单词)

TextCapitalization.characters:输入的内容全部都大写

TextCapitalization.sentences:输入的内容首字母大写

TextCapitalization.none:默认情况,什么都不设置

8、onChanged

这个属性用来监听输入框的输入,类似Android的TextWatch,但是它只有输入后的值:

1new TextField(
2  onChanged: (String content) {
3    print('content--->$content');
4  },
5)

9、cursorWidth、cursorRadius、cursorColor

这几个属性用来设置输入时候的光标。

 1new TextField(
 2  decoration: InputDecoration(
 3    hintText: '光标设置',
 4    hintStyle: TextStyle(
 5      fontSize: 14,
 6      color: Colors.grey,
 7    ),
 8  ),
 9  cursorColor: Colors.purple,
10  cursorWidth: 6,
11  cursorRadius: Radius.elliptical(2, 8),
12)

原文发布时间为:2018-12-13
本文作者: 24K纯帅豆
本文来自云栖社区合作伙伴“ IT先森养成记”,了解相关信息可以关注“cyg_24kshign”微信公众号

相关文章
|
3月前
Flutter 组件(二)文本 与 输入框组件
Flutter 组件(二)文本 与 输入框组件
62 0
|
3月前
|
容器
Flutter 组件(一)组件概述
Flutter 组件(一)组件概述
52 0
|
7月前
|
人机交互
Flutter笔记 - ListTile组件及其应用
Flutter笔记 - ListTile组件及其应用
93 0
|
3月前
|
开发者 索引 容器
Flutter开发笔记:Flutter 布局相关组件
Flutter开发笔记:Flutter 布局相关组件
119 0
|
3月前
|
iOS开发
Flutter 组件(三)按钮类组件
Flutter 组件(三)按钮类组件
149 0
|
4月前
|
Dart Unix
Flutter 学习 之 时间转换工具类
Flutter 学习之时间转换工具类 在 Flutter 应用程序开发中,处理时间戳是非常常见的需求。我们通常需要将时间戳转换为人类可读的日期时间格式。为了实现这一点,我们可以创建一个时间转换工具类。
|
4月前
|
Dart
Flutter 学习之图片的选择、裁切、保存
Flutter 学习之图片的选择、裁切、保存 在Flutter中,我们可以通过调用系统的图片选择器来选择一张图片,也可以通过使用插件来实现图片的裁切和保存。
|
9月前
|
缓存 Dart 前端开发
Flutter 中使用 Widgetbook 管理你的组件 | 猫哥
Flutter 界面开发中我们有几个痛点 : - 与设计师协作复用一套设计规范(figma) - 可视化的管理你的组件代码(基础组件、业务组件) - 不同设备尺寸测试你的组件 - 实时修改你的测试组件参数
4212 1
Flutter 中使用 Widgetbook 管理你的组件 | 猫哥
|
6月前
|
API 开发者 索引
Flutter笔记:发布一个多功能轮播组件 awesome_carousel
awesome_carousel 模块是一个Flutter轮播图模块。可以实现包括自定义指示器、动画、滚动等等众多功能。能够指定相当多地细节(可以参考 API 部分了解)本文给出 awesome_carousel 模块的两个简单的用法示例。
74 0
|
8月前
|
Dart 开发工具 开发者
如何快速的学习认识Flutter
学习和掌握Flutter需要一定的时间和实践,但以下步骤可以帮助你快速入门并认识Flutter: 1.学习Dart语言:Flutter使用Dart作为开发语言,所以首先要熟悉Dart语法和基本概念。你可以查阅Dart官方文档、教程或在线课程来学习Dart的基础知识。 2.安装Flutter:访问Flutter官方网站,下载并安装适用于你操作系统的Flutter SDK。按照官方文档中的指引进行配置和设置。 3.创建Flutter项目:使用Flutter命令行工具(flutter CLI)创建一个新的Flutter项目。在命令行中运行以下命令: