【Flutter 实战】全局点击空白处隐藏键盘

老孟导读:为何要实现点击空白处隐藏键盘?由于这是 iOS 平台的默认行为,Android 平台因为其弹出的键盘右上角默认带有关闭键盘的按钮,因此点击空白处不会隐藏键盘。git

对于单个页面来讲,经过为 TextField 添加 focusNode,点击空白处时使 TextField 失去焦点,实现以下:微信

class DismissKeyboardDemo extends StatelessWidget {
  final FocusNode focusNode = FocusNode();

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      body: GestureDetector(
        onTap: () {
          focusNode.unfocus();
        },
        child: Container(
          color: Colors.transparent,
          alignment: Alignment.center,
          child: TextField(
            focusNode: focusNode,
          ),
        ),
      ),
    );
  }
}

当 App 中有多个页面多个 TextField 时,此方式会增长大量重复的代码,所以全局添加点击空白处的监听:app

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      builder: (context, child) => Scaffold(
        body: GestureDetector(
          onTap: () {
            FocusScopeNode currentFocus = FocusScope.of(context);
            if (!currentFocus.hasPrimaryFocus &&
                currentFocus.focusedChild != null) {
              FocusManager.instance.primaryFocus.unfocus();
            }
          },
          child: child,
        ),
      ),
      home: DismissKeyboardDemo(),
    );
  }
}

也能够使用以下方式隐藏键盘:less

SystemChannels.textInput.invokeMethod('TextInput.hide');

修改 DismissKeyboardDemo 页面:ide

class DismissKeyboardDemo extends StatelessWidget {

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      body: Center(
        child: TextField(),
      ),
    );
  }
}

效果和上面是同样的,一样能够实现点击空白处隐藏键盘。ui

交流

老孟Flutter博客地址(330个控件用法):http://laomengit.comspa

欢迎加入Flutter交流群(微信:laomengit)、关注公众号【老孟Flutter】:code