
老孟導(dǎo)讀:為什么要實(shí)現(xiàn)點(diǎn)擊空白處隱藏鍵盤?因?yàn)檫@是 iOS 平臺(tái)的默認(rèn)行為,Android 平臺(tái)由于其彈出的鍵盤右上角默認(rèn)帶有關(guān)閉鍵盤的按鈕,所以點(diǎn)擊空白處不會(huì)隱藏鍵盤。
對(duì)于單個(gè)頁面來說,通過為 TextField 添加 focusNode,點(diǎn)擊空白處時(shí)使 TextField 失去焦點(diǎn),實(shí)現(xiàn)如下:
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,
),
),
),
);
}
}

當(dāng) App 中有多個(gè)頁面多個(gè) TextField 時(shí),此方式會(huì)增加大量重復(fù)的代碼,因此全局添加點(diǎn)擊空白處的監(jiān)聽:
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(),
);
}
}
也可以使用如下方式隱藏鍵盤:
SystemChannels.textInput.invokeMethod('TextInput.hide');
修改 DismissKeyboardDemo 頁面:
class DismissKeyboardDemo extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(),
body: Center(
child: TextField(),
),
);
}
}
效果和上面是一樣的,同樣可以實(shí)現(xiàn)點(diǎn)擊空白處隱藏鍵盤。
交流
老孟Flutter博客地址(330個(gè)控件用法):http://laomengit.com
歡迎加入Flutter交流群(微信:laomengit)、關(guān)注公眾號(hào)【老孟Flutter】: