html表单text内文字,表单 TextFormField简单使用

(一)设置表单的自动验证功能

1,首先创建一个StatefulWidget,在build 方法中返回一个Form表单组件

930d33e15229033252d7fb71b9d5c805.png

2,创建一个GlobalKey,设置给Form的key属性

61515485a88ab3c09ba2c9c0b21c2701.png

3,创建一个表单控件TextFormField,添加实现validator函数,简单实现用户是否输入文本

a0d6a723f48fe388f0a05b353b98c0c7.png

4,添加一个button,触发验证函数,如果用户输入了数据,显示一个SnackBar正在处理

75b0f81cca686d2ab6d3153179a9ff8e.png

(二)设置设置TextFormField的样式

1,TextFormFiled 有一个属性decoration,默认是 InputDecoration

fee79c0130857a0e9d50edb723c568c2.png

2,设置InputDecoration里面的border属性,可以设置三个值,InputBorder.none没有边框,UnderlineInputBorder默认的边框样式,输入框下边有一条线,OutlineInputBorder四周都有一条线,可以设置corder,width, color等属性

3d0bfef9412457267fd7c2f1271a5746.png

(三)TextFormField自动获取焦点和手动获取焦点

1,自动获取焦点,只要设置autofocus属性为true

9e447ae20119dbfc857889264952ef6b.png

2,手动获取焦点,要定义一个FocusNode对象,然后赋值给TextFormField的focusNode属性

4434a89e7be6d2540d25e272e14825e6.png

3,添加一个button,手动出发获取焦点,调用requestFocus方法

369f4121229692fd9a3c892e437a8c45.png

(四),监听TextFormField文字的变化

1,创建一个TextEditingController,赋值给TextFormField的controller属性

4b3991483e842a1c99e22b4e35ed6eee.png

2,在initState方法中给controller添加listener

2b5936ae99688f8d2d0865e5680cb05c.png

3,通过controller的text属性来获取用户输入的值

563fd3a5c1c1fee43634ca107ba8f7c4.png

最后创建的FocusNode 和TextEditingController都要释放资源

c1198e20e407d6e89c3827618f8ec58c.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值