一文解決Flutter中使用TextField遇到的各種疑難雜癥

頁面中有輸入框呻澜,鍵盤彈起,頁面溢出

可以使用 SingleChildScrollView 包裹布局
這里還需要了解一個 Scaffold 中的一個屬性 resizeToAvoidBottomInset

/// If true the [body] and the scaffold's floating widgets should size
/// themselves to avoid the onscreen keyboard whose height is defined by the
/// ambient [MediaQuery]'s [MediaQueryData.viewInsets] bottom property.
///
/// For example, if there is an onscreen keyboard displayed above the
/// scaffold, the body can be resized to avoid overlapping the keyboard, which
/// prevents widgets inside the body from being obscured by the keyboard.
///
/// Defaults to true.

官方文檔給出的解釋就是處理鍵盤遮擋問題,默認是 true亚皂,如果不希望頂起需要設置為 false这橙。
在 sdk 低版本的時候是使用 resizeToAvoidBottomPadding 需要將其設置為 false,現(xiàn)在已經(jīng)棄用扭粱。但網(wǎng)上很多文章還沒有改正,仍然用的 resizeToAvoidBottomPadding震檩。

鍵盤彈起的情況下琢蛤,返回前先收起鍵盤

分兩種情況
一種是使用系統(tǒng)的返回鍵蜓堕,比如 android 底部導航自帶的返回,
另一種是使用導航欄自定義的返回鍵
第一種情況需要在頁面根布局使用 WillPopScope 在 onWillPop 中攔截返回處理博其。
原理都是通過判斷輸入框是否獲取了焦點

      onWillPop: () {
        if (_focusNode.hasFocus) {
          FocusScope.of(context).unfocus();
        } else {
          return Future.value(true);
        }
      },

編輯頁面底部有懸浮按鈕套才,鍵盤彈起的時候,要頂上去慕淡,保證按鈕不被鍵盤遮擋

當?shù)撞坑泄潭ǖ慕M件背伴,比如提交按鈕,我們在鍵盤彈起的時候希望按鈕貼著鍵盤頂部固定峰髓,但是中間滾動視圖可以自由滾動
可以在 SingleChildScrollView 外部再使用 Stack 包裹傻寂,懸浮按鈕使用 Positioned 定位,
還要??注意要給滾動組件底部留出距離防遮擋携兵,同時還有動態(tài)加上 bottomBar 的高度疾掰,因為在 iphoneX 以上的手機,會有個虛擬按鍵徐紧,如果不加上該按鍵高度静檬,同樣會被遮擋
高度獲取方法:MediaQuery.of(context).padding.bottom

dialog彈窗中有輸入框,彈起鍵盤布局溢出

在 showDialog 布局中使用 Scaffold 包裹并级,不要忘了將 backgroundColor 設為透明拂檩。
如果彈窗過高,還是需要將高度固定嘲碧,然后使用 SingleChildScrollView 广恢,彈窗中同樣也可以在執(zhí)行關閉的時候攔截,判斷鍵盤是否彈起呀潭,如果彈起則要先關閉鍵盤钉迷。

    showDialog(
        context: context,
        builder: (c) {
          return Scaffold(
            backgroundColor: Colors.transparent,
            body: Container(
                height: BaseTheme.getScreenHeight() * 0.4,
                padding: EdgeInsets.only(left: 8.w, right: 8.w),
                child: SingleChildScrollView(
                  child: Column(
                    crossAxisAlignment: CrossAxisAlignment.start,
                    children: [
                    ],
                  ),
                ),
            ),
          );
        });

鍵盤焦點完成切換,切換到最后一個后钠署,關閉

給所有輸入框綁定 FoucusNode
在 maxLines=1 的情況下糠聪,輸入框不支持換行,換行按鈕會變成 done
監(jiān)聽 onEditingComplete 方法

                onEditingComplete: () {
                  if (code.isEmpty) {
                    //如果還有其它未填寫的輸入框谐鼎,則切換焦點過去
                    FocusScope.of(context).requestFocus(_focusNode);
                    return;
                  }
                  //收起鍵盤
                  FocusScope.of(context).unfocus();
                },

點擊輸入框以外的區(qū)域收起鍵盤

根布局使用 GestureDetector 或者 InkWell 包裹舰蟆,點擊的時候收起鍵盤。

監(jiān)聽軟鍵盤是否彈出

  • 可以用第三方插件比如
    https://pub.dev/packages/flutter_keyboard_visibility
    大概使用用法是使用組件包裹狸棍,通過回調(diào)監(jiān)聽身害,然后根據(jù)狀態(tài)自己處理
  • _focusNode.hasFocus
    這個方法在前面有提過,也是最簡單的辦法草戈,局限性就是需要動作去觸發(fā)檢測塌鸯。此方法適用于在點擊返回按鈕的時候
                    onTap: () {
                      if (_focusNode.hasFocus || _focusNodeNote.hasFocus) {
                        FocusScope.of(context).unfocus();
                        return;
                      }
                      Navigator.pop(context);
                    }
  • 使用 WidgetsBinding 添加監(jiān)聽
    首先頁面要 with WidgetsBindingObserver
    然后 在 initState() 實例化監(jiān)聽
    WidgetsBinding.instance.addObserver(this);
    實現(xiàn) didChangeMetrics() 方法
  void didChangeMetrics() {
    super.didChangeMetrics();
    WidgetsBinding.instance.addPostFrameCallback((_) {
      if(MediaQuery.of(context).viewInsets.bottom==0){
        LogUtils.v("關閉鍵盤");
      }else{
        LogUtils.v("顯示鍵盤");
      }
    });
  }

最后要記得銷毀

   @override
  void dispose() {
    // TODO: implement dispose
    //銷毀
    WidgetsBinding.instance.removeObserver(this);

    super.dispose();
  }

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市唐片,隨后出現(xiàn)的幾起案子丙猬,更是在濱河造成了極大的恐慌涨颜,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件茧球,死亡現(xiàn)場離奇詭異庭瑰,居然都是意外死亡,警方通過查閱死者的電腦和手機抢埋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門弹灭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人揪垄,你說我怎么就攤上這事穷吮。” “怎么了福侈?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵酒来,是天一觀的道長卢未。 經(jīng)常有香客問我肪凛,道長,這世上最難降的妖魔是什么辽社? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任伟墙,我火速辦了婚禮,結果婚禮上滴铅,老公的妹妹穿的比我還像新娘戳葵。我一直安慰自己,他們只是感情好汉匙,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布拱烁。 她就那樣靜靜地躺著,像睡著了一般噩翠。 火紅的嫁衣襯著肌膚如雪戏自。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天伤锚,我揣著相機與錄音擅笔,去河邊找鬼。 笑死屯援,一個胖子當著我的面吹牛猛们,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播狞洋,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼弯淘,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了吉懊?” 一聲冷哼從身側響起耳胎,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤惯吕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后怕午,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體废登,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年郁惜,在試婚紗的時候發(fā)現(xiàn)自己被綠了堡距。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡兆蕉,死狀恐怖羽戒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情虎韵,我是刑警寧澤易稠,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站包蓝,受9級特大地震影響驶社,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜测萎,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一亡电、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧硅瞧,春花似錦份乒、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至枣接,卻和暖如春颂暇,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背月腋。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工蟀架, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人榆骚。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓片拍,卻偏偏與公主長得像,于是被迫代替她去往敵國和親妓肢。 傳聞我的和親對象是個殘疾皇子捌省,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內(nèi)容