5.Flutter-基础组件(输入框及表单)

Material 组件库中提供了输入框组件TextField和表单组件Form。下面我们分别介绍一下

5.1 TextField

TextField用于文本输入,它提供了很多属性,我们先简单介绍一下主要属性的作用,然后通过几个示例来演示一下关键属性的用法。

TextField关键属性的用法

controller:编辑框的控制器,通过它可以设置/获取编辑框的内容、选择编辑内容、监听编辑文本改变事件。大多数情况下我们都需要显式提供一个controller来与文本框交互。如果没有提供controller,则TextField内部会自动创建一个。

定义一个控制器用来监听输入以及初始化赋值等等
监听TextField输入

focusNode:用于控制TextField是否占有当前键盘的输入焦点。它是我们和键盘交互的一个句柄(handle通过焦点的控制来关闭键盘,或者移动到下一个TextField)。

        1.点击完成键盘完成按钮,焦点自动跳转到下一个TextField

FocusScopeNode方式焦点自动跳转

        2.控制具体某一个焦点,requestFous(FocusNode),聚焦某个具体的TextField,代码如下

聚焦某个具体的TextField

 3.隐藏键盘

对应的FocusNode.unfous()或者 FocusManager.instance.primaryFocus.unfocus();

4.自动跳转焦点的时候跳过部分控件

自动跳转焦点的时候跳过部分控件

5.焦点监听

  FocusNode继承自ChangeNotifier,通过FocusNode可以监听焦点的改变事件,如:

获得焦点时focusNode.hasFocus值为true,失去焦点时为false

InputDecoration:用于控制TextField的外观显示,如提示文本、背景颜色、边框等。

InputDecoration 外观显示设置

keyboardType:用于设置该输入框默认的键盘输入类型,取值如下:

设置该输入框默认的键盘输入类型
keyboardType键盘类型代码以及效果图

textInputAction:键盘动作按钮图标(即回车键位图标),它是一个枚举值,有多个可选值,全部的取值列表读者可以查看API文档,下面是当值为TextInputAction.search时,原生Android系统下键盘样

键盘回车键图标设置

style:正在编辑的文本样式。

textAlign: 输入框内编辑文本在水平方向的对齐方式。

autofocus: 是否自动获取焦点。

obscureText:是否隐藏正在编辑的文本,如用于输入密码的场景等,文本内容会用“•”替换。

maxLines:输入框的最大行数,默认为1;如果为null,则无行数限制。

maxLengthmaxLengthEnforcement :maxLength代表输入框文本的最大长度,设置后输入框右下角会显示输入的文本计数。maxLengthEnforcement决定当输入文本长度超过maxLength时如何处理,如截断、超出等。

toolbarOptions:长按或鼠标右击时出现的菜单,包括 copy、cut、paste 以及 selectAll。

onChange:输入框内容改变时的回调函数;注:内容改变事件也可以通过controller来监听。

onEditingCompleteonSubmitted:这两个回调都是在输入框输入完成时触发,比如按了键盘的完成键(对号图标)或搜索键(图标)。不同的是两个回调签名不同,onSubmitted回调是ValueChanged类型,它接收当前输入内容做为参数,而onEditingComplete不接收参数。

inputFormatters:用于指定输入格式;当用户输入内容改变时,会根据指定的格式来校验。

enable:如果为false,则输入框会被禁用,禁用状态不接收输入和事件,同时显示禁用态样式(在其decoration中定义)。

cursorWidthcursorRadiuscursorColor:这三个属性是用于自定义输入框光标宽度、圆角和颜色的

对应的属性值
光标样式效果图
复制粘贴全选

5.2 Form表单

实际业务中,在正式向服务器提交数据前,都会对各个输入框数据进行合法性校验,但是对每一个TextField都分别进行校验将会是一件很麻烦的事。还有,如果用户想清除一组TextField的内容,除了一个一个清除有没有什么更好的办法呢?为此,Flutter提供了一个Form 组件,它可以对输入框进行分组,然后进行一些统一操作,如输入内容校验、输入框重置以及输入内容保存。


1.Form

Form继承自StatefulWidget对象,它对应的状态类为FormState。我们先看看Form类的定义

Form组件相关参数

autovalidate:是否自动校验输入内容;当为true时,每一个子 FormField 内容发生变化时都会自动校验合法性,并直接显示错误信息。否则,需要通过调用FormState.validate()来手动校验。

onWillPop:决定Form所在的路由是否可以直接返回(如点击返回按钮),该回调返回一个Future对象,如果 Future 的最终结果是false,则当前路由不会返回;如果为true,则会返回到上一个路由。此属性通常用于拦截返回按钮。

onChanged:Form的任意一个子FormField内容发生变化时会触发此回调。

2.FormField

Form的子孙元素必须是FormField类型,FormField是一个抽象类,定义几个属性,FormState内部通过它们来完成操作,FormField部分定义如下:

FormField类型

为了方便使用,Flutter 提供了一个TextFormField组件,它继承自FormField基础类,也是TextField的一个包装类,所以除了FormField定义的属性之外,它还包括TextField的属性。所以我们一般都用TextFormField和From一起使用

3. FormState

FormState为Form的State类,可以通过Form.of()或GlobalKey获得。我们可以通过它来对Form的子孙FormField进行统一操作。我们看看其常用的三个方法:

FormState.validate():调用此方法后,会调用Form子孙FormField的validate回调,如果有一个校验失败,则返回false,所有校验失败项都会返回用户返回的错误提示。

FormState.save():调用此方法后,会调用Form子孙FormField的save回调,用于保存表单内容

FormState.reset():调用此方法后,会将子孙FormField的内容清空

4.完整的示例

Form组件和TextFormField组件
相关逻辑方法校验

你可能感兴趣的:(5.Flutter-基础组件(输入框及表单))