Flutter监听TextField焦点事件,点击与清除焦点
- 发表于
- flutter
点击任意位置取消TextField焦点
监听TextField焦点,如何在单击屏幕上的任意位置后隐藏软键盘?
之前我们是这么用的:
// 清除焦点
FocusScope.of(context).requestFocus(new FocusNode());
要实现点击任何位置清除焦点,只需要用GestureDetector方法包裹整个布局,然后onTap方法编写此代码,即可隐藏软键盘:
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:
final focusNode = FocusNode();
// ...
focusNode.unfocus();
如果您尚未明确声明FocusNode,请使用“常规”方法:
FocusScope.of(context).requestFocus(new FocusNode());
如果您需要:1、消除键盘;2、取消焦点文本字段:
FocusScope.of(context).detach();
官方文档说,即使没有焦点,分离也可以安全使用。
如果您只想隐藏键盘而不丢失文本字段焦点:
import 'package:flutter/services.dart' show SystemChannels;
SystemChannels.textInput.invokeMethod('TextInput.hide');
原文连接:Flutter监听TextField焦点事件,点击与清除焦点
所有媒体,可在保留署名、
原文连接
的情况下转载,若非则不得使用我方内容。