【Flutter 實(shí)戰(zhàn)】全局點(diǎn)擊空白處隱藏鍵盤

老孟導(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】:

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容