Flutter中表單控件的使用

一胸遇、Flutter中TextField控件在使用的時候在設置邊框InputBorder

Flutter中TextField控件在使用的時候在設置邊框時有如下幾種:

  • InputBorder? errorBorder:在InputDecorate沒有焦點顯示錯誤的時候使用
  • InputBorder? focusedBorder:在InputDecorate有焦點且不顯示錯誤的時候使用
  • InputBorder? focusedErrorBorder:在InputDecorate有焦點且顯示錯誤的時候使用
  • InputBorder? disabledBorder:在InputDecorate不能使用且不顯示錯誤的時候使用
  • InputBorder? enabledBorder:在InputDecorate能使用且不顯示錯誤的時候使用
  • InputBorder? border:在輸入框上繪制

不同狀態(tài)下的邊框樣式,他們接收值的類型都一樣,不過需要注意優(yōu)先級。
大致分為以下幾種情況

  1. 控件禁用時當enabled為false時,如果指定了disabledBorder,優(yōu)先使用disabledBorder,沒有的話設置disabledBorder則使用border的部分樣式(顏色默認是灰色)

  2. 控件啟用(enable為true)呆奕,但errorText有值輸入框沒有焦點時,優(yōu)先使用errorBorder的樣式衬吆,輸入框有焦點時梁钾,優(yōu)先使用focusedErrorBorder,如果這兩個都沒有設置則使用border的部分樣式(顏色默認是紅色)

  3. 控件啟用狀態(tài)咆槽,且errorText沒有值輸入框沒有焦點時陈轿,優(yōu)先使用enabledBorder ,有焦點時秦忿,優(yōu)先使用focusedBorder麦射,兩者均沒有指定時,使用默認的border

總體來說灯谣,默認的border優(yōu)先級別較低潜秋。
建議:

  • 在開發(fā)過程中我們如果需要errorText的話,我們只需要設置 errorBorder胎许、focusedErrorBorder這三個即可峻呛。不需要errorText的話
  • 不需要errorText的話罗售,只需要設置enabledBorder 、focusedBorder
// 1. 控件禁用時 當enabled為false時钩述,如果指定了disabledBorder寨躁,優(yōu)先使用disabledBorder,
// 沒有的話設置disabledBorder則使用border的部分樣式(顏色默認是灰色)
enabled: false,
disabledBorder: OutlineInputBorder(
  borderSide: BorderSide(color: Colors.red),
  borderRadius: BorderRadius.all(Radius.circular(10)),
),

// 2. 控件啟用(enable為true)牙勘,但errorText有值輸入框沒有焦點時职恳,優(yōu)先使用errorBorder的樣式,
// 輸入框有焦點時方面,優(yōu)先使用focusedErrorBorder放钦,如果這兩個都沒有設置則使用border的部分樣式(顏色默認是紅色)
errorText: '出錯了',
errorBorder: OutlineInputBorder(
  borderSide: BorderSide(color: Colors.red),
  borderRadius: BorderRadius.all(Radius.circular(10)),
),
focusedErrorBorder: OutlineInputBorder(
  borderSide: BorderSide(color: Colors.green),
  borderRadius: BorderRadius.all(Radius.circular(10)),
),
    
// 3、控件啟用狀態(tài)恭金,且errorText沒有值輸入框沒有焦點時操禀,優(yōu)先使用enabledBorder ,
// 有焦點時横腿,優(yōu)先使用focusedBorder颓屑,兩者均沒有指定時,使用默認的border
enabledBorder: OutlineInputBorder(
  borderSide: BorderSide(color: Colors.yellow),
  borderRadius: BorderRadius.all(Radius.circular(10)),
),
focusedBorder: OutlineInputBorder(
  borderSide: BorderSide(color: Colors.green),
  borderRadius: BorderRadius.all(Radius.circular(10)),
),   

// 隱藏下劃線
// border: InputBorder.none,
border: OutlineInputBorder(
  borderSide: BorderSide(color: Colors.red),
  borderRadius: BorderRadius.all(Radius.circular(10)),
),              

二蔑水、Flutter中使用TextField控件中的事件

  • final ValueChanged<String>? onChanged;
  • final VoidCallback? onEditingComplete;
  • final ValueChanged<String>? onSubmitted;
  • final GestureTapCallback? onTap;
TextField(
  decoration: InputDecoration(
    hintText: hintText,
    // 隱藏下劃線
    border: InputBorder.none,
    // 顏色填充
    // filled: true,
    // fillColor: Colors.cyan,
  ),

  // 輸入文本發(fā)生變化時的回調邢锯,參數即為輸入框中的值
  onChanged: (value) {
    print(value)
  },
  // 點擊鍵盤的動作按鈕時的回調扬蕊,沒有參數搀别,注意這個方法使用后點擊鍵盤上的動作按鈕就不會自動收起鍵盤了
  onEditingComplete: () {
    print('點擊了鍵盤上的動作按鈕!');
  },
  // 點擊鍵盤的動作按鈕時的回調尾抑,參數為當前輸入框中的值
  onSubmitted: (value) {
    print('當前輸入框中的值為:$value');
  },
  // 點擊輸入框的時候就觸發(fā)歇父,當設置了enabled: false的話則點擊無效
  // enabled: false,
  onTap: () {
    print('點擊按鈕');
  },
),

三、點擊空白 input 失去焦點

需要在頁面的Scaffold外層加如下代碼:

GestureDetector(
    behavior: HitTestBehavior.translucent,
    onTap: () {
        // 方式一:
        FocusScope.of(context).requestFocus(FocusNode());
        // 方式二:(與方式一的區(qū)別在于再愈,鍵盤收起后文本是否失去焦點)
        SystemChannels.textInput.invokeMethod('TextInput.hide');
        // 方式三:還可以將所有的FocusNode進行包裝整體進行取消
        // unFocus();
    },
    child: Scaffold(
        ...
    )
);

void unFocus() {
    phoneFocusNode.unfocus();
    passwordFocusNode.unfocus();
    dateFocusNode.unfocus();
}

注意:FocusScope.of(context).requestFocus(FocusNode());這種應該是獲取焦點的方式榜苫,當傳入具體的focusNode的話,該輸入框就會獲取焦點翎冲,彈出鍵盤垂睬,如果沒有具體指定,只是傳入一個FocusNode()的實例抗悍,會收起鍵盤驹饺,具體原因,需要查一下源碼缴渊,mark一下赏壹。

四、常用正則校驗

// 字母
RegExp letterReg = RegExp("[a-zA-Z]");
// 中文正則
RegExp chineseReg = RegExp("[\u4e00-\u9fa5]");
// 字母衔沼、數字和漢字正則
RegExp letterDigitChineseReg = RegExp("[a-zA-Z]|[\u4e00-\u9fa5]|[0-9]");
// emoji表情正則
RegExp emojiReg = RegExp(
    "[^\\u0020-\\u007E\\u00A0-\\u00BE\\u2E80-\\uA4CF\\uF900-\\uFAFF\\uFE30-\\uFE4F\\uFF00-\\uFFEF\\u0080-\\u009F\\u2000-\\u201f\r\n]");

使用TextInputFormatter對輸入內容增加校驗:

// 用于限制輸入的內容蝌借,接收一個TextInputFormatter類型的集合
inputFormatters: [
    // 白名單設置昔瞧,只允許輸入小寫的a-z
    // FilteringTextInputFormatter.allow(RegExp("[a-z]")),
    // 黑名單設置,不允許輸入emoji表情和中文
    FilteringTextInputFormatter.deny(emojiReg),
    FilteringTextInputFormatter.deny(chineseReg),
    // 只允許輸入數字
    // FilteringTextInputFormatter.digitsOnly,
    // FilteringTextInputFormatter.singleLineFormatter,
    // LengthLimitingTextInputFormatter(5)
],
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末菩佑,一起剝皮案震驚了整個濱河市自晰,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌稍坯,老刑警劉巖缀磕,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異劣光,居然都是意外死亡袜蚕,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進店門绢涡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來牲剃,“玉大人,你說我怎么就攤上這事雄可≡涓担” “怎么了?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵数苫,是天一觀的道長聪舒。 經常有香客問我,道長虐急,這世上最難降的妖魔是什么箱残? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮止吁,結果婚禮上被辑,老公的妹妹穿的比我還像新娘。我一直安慰自己敬惦,他們只是感情好盼理,可當我...
    茶點故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著俄删,像睡著了一般宏怔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上畴椰,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天臊诊,我揣著相機與錄音,去河邊找鬼迅矛。 笑死妨猩,一個胖子當著我的面吹牛,可吹牛的內容都是我干的秽褒。 我是一名探鬼主播壶硅,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼威兜,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了庐椒?” 一聲冷哼從身側響起椒舵,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎约谈,沒想到半個月后笔宿,有當地人在樹林里發(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡棱诱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年泼橘,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片迈勋。...
    茶點故事閱讀 38,039評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡炬灭,死狀恐怖,靈堂內的尸體忽然破棺而出靡菇,到底是詐尸還是另有隱情重归,我是刑警寧澤,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布厦凤,位于F島的核電站鼻吮,受9級特大地震影響,放射性物質發(fā)生泄漏较鼓。R本人自食惡果不足惜椎木,卻給世界環(huán)境...
    茶點故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望笨腥。 院中可真熱鬧拓哺,春花似錦勇垛、人聲如沸脖母。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽谆级。三九已至,卻和暖如春讼积,著一層夾襖步出監(jiān)牢的瞬間肥照,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工勤众, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留舆绎,地道東北人。 一個月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓们颜,卻偏偏與公主長得像吕朵,于是被迫代替她去往敵國和親猎醇。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,786評論 2 345

推薦閱讀更多精彩內容