【Flutter 實戰】全局點擊空白處隱藏鍵盤


老孟導讀:為什么要實現點擊空白處隱藏鍵盤?因為這是 iOS 平台的默認行為,Android 平台由於其彈出的鍵盤右上角默認帶有關閉鍵盤的按鈕,所以點擊空白處不會隱藏鍵盤。

對於單個頁面來說,通過為 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 時,此方式會增加大量重復的代碼,因此全局添加點擊空白處的監聽:

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(),
      ),
    );
  }
}

效果和上面是一樣的,同樣可以實現點擊空白處隱藏鍵盤。

交流

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

歡迎加入Flutter交流群(微信:laomengit)、關注公眾號【老孟Flutter】:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM