Flutter监听TextField焦点事件,点击与清除焦点
- 发表于
- flutter
点击任意位置取消TextField焦点
监听TextField焦点,如何在单击屏幕上的任意位置后隐藏软键盘?
之前我们是这么用的:
1 2 |
// 清除焦点 FocusScope.of(context).requestFocus(new FocusNode()); |
要实现点击任何位置清除焦点,只需要用GestureDetector方法包裹整个布局,然后onTap方法编写此代码,即可隐藏软键盘:
1 2 3 4 5 6 7 8 9 |
new Scaffold( body: new GestureDetector( onTap: () { FocusScope.of(context).requestFocus(new FocusNode()); }, child: new Container( //rest of your code write here ) ) |
新的方法
unfocus
从具有主要焦点的节点上删除焦点,并取消所有未完成的聚焦请求。调用requestFocus将一个请求发送到FocusManager以使该节点成为主要焦点,该节点计划以最新请求解析为树上焦点状态的更新。调用unfocus会取消已请求但尚未执行的请求。
无论此节点是否曾经请求过焦点,都可以安全地调用此方法。
如果声明了FocusNode聚焦文本字段,请使用unfocus:
1 2 3 |
final focusNode = FocusNode(); // ... focusNode.unfocus(); |
如果您尚未明确声明FocusNode,请使用“常规”方法:
1 |
FocusScope.of(context).requestFocus(new FocusNode()); |
如果您需要:1、消除键盘;2、取消焦点文本字段:
1 |
FocusScope.of(context).detach(); |
官方文档说,即使没有焦点,分离也可以安全使用。
如果您只想隐藏键盘而不丢失文本字段焦点:
1 2 3 |
import 'package:flutter/services.dart' show SystemChannels; SystemChannels.textInput.invokeMethod('TextInput.hide'); |
原文连接:Flutter监听TextField焦点事件,点击与清除焦点
所有媒体,可在保留署名、
原文连接
的情况下转载,若非则不得使用我方内容。