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})
AI 代码解读

哇,乍一看好多配置啊,别急大兄弟,有很多我们在讲 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)
AI 代码解读

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)
AI 代码解读

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)
AI 代码解读

4、keyboardType

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

text 输入文字

multiline 输入文字

number 输入文字

phone 输入文字

datetime 输入文字

emailAddress 输入文字

url

1new TextField(
2  keyboardType: TextInputType.number,
3)
AI 代码解读

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)
AI 代码解读

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)
AI 代码解读

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

相关文章
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
190 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
136 75
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
25天前
|
【Flutter 开发必备】AzListView 组件全解析,打造丝滑索引列表!
在 Flutter 开发中,AzListView 是实现字母索引分类列表的理想选择。它支持 A-Z 快速跳转、悬浮分组标题、自定义 UI 和高效性能,适用于通讯录、城市选择等场景。本文将详细解析 AzListView 的核心参数和实战示例,助你轻松实现流畅的索引列表。
41 7
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
110 18
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
249 26
Flutter 学习之封装 WebView
【10月更文挑战第24天】通过以上的探讨,我们可以看出,在 Flutter 中封装 WebView 是非常有必要的,它可以提高代码的复用性、增强可维护性、提供统一接口。在实际应用中,我们需要根据具体的需求和场景,选择合适的封装方法和技术,以实现更好的效果。
Flutter 框架提供了丰富的机制和方法来优化键盘处理和输入框体验
在移动应用开发中,Flutter 框架提供了丰富的机制和方法来优化键盘处理和输入框体验。本文深入探讨了键盘的显示与隐藏、输入框的焦点管理、键盘类型的适配、输入框高度自适应、键盘遮挡问题处理及性能优化等关键技术,结合实例分析,旨在帮助开发者提升应用的用户体验。
170 6
如何学习 Flutter 框架?
学习 Flutter 需要耐心和持续的努力,通过系统的学习、实践、交流和不断跟进最新技术,你将逐渐掌握 Flutter 框架,并能够开发出高质量的移动应用。
|
4月前
Flutter 自定义组件继承与调用的高级使用方式
本文深入探讨了 Flutter 中自定义组件的高级使用方式,包括创建基本自定义组件、继承现有组件、使用 Mixins 和组合模式等。通过这些方法,您可以构建灵活、可重用且易于维护的 UI 组件,从而提升开发效率和代码质量。
178 1
Flutter&鸿蒙next中封装一个输入框组件
本文介绍了如何创建一个简单的Flutter播客应用。首先,通过`flutter create`命令创建项目;接着,在`lib`目录下封装一个自定义输入框组件`CustomInput`;然后,在主应用文件`main.dart`中使用该输入框组件,实现简单的UI布局和功能;最后,通过`flutter run`启动应用。本文还提供了后续扩展建议,如状态管理、网络请求和UI优化。
130 1

热门文章

最新文章

  • 1
    【Flutter 开发必备】AzListView 组件全解析,打造丝滑索引列表!
    41
  • 2
    flutter3-wetrip跨平台自研仿携程app预约酒店系统模板
    46
  • 3
    通过外部链接启动 Flutter App(详细介绍及示例)
    40
  • 4
    【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
    218
  • 5
    零基础构建即时通讯开源项目OpenIM移动端-Flutter篇
    116
  • 6
    flutter3-dart3-dymall原创仿抖音(直播+短视频+聊天)商城app系统模板
    80
  • 7
    【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
    190
  • 8
    【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
    64
  • 9
    当flutter react native 等混开框架-并且用vscode-idea等编译器无法打包apk,打包安卓不成功怎么办-直接用android studio如何打包安卓apk -重要-优雅草卓伊凡
    91
  • 10
    【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
    193