Flutter開(kāi)發(fā)中的一些小技巧整理

一藕甩、Text 組件外圍包裹了 GestureDetector 手勢(shì)組件點(diǎn)擊的時(shí)候響應(yīng)范圍太小

解決方式:

  1. Text 外圍使用 TextButton 包裹
  2. 使用 InkWell 組件包裹

二富拗、List 的使用

在數(shù)據(jù)量比較小的時(shí)候比如固定布局,可以使用 List.generate() 次企,來(lái)循環(huán)渲染脯颜。
ListView.builder 適用于列表長(zhǎng)度比較多虽画,比如存在分頁(yè)數(shù)據(jù)舞蔽,
ListView.builder 外部如果有其他組件需要一起滾動(dòng),則需要 禁用內(nèi)部的滾動(dòng)事件
physics: NeverScrollableScrollPhysics(),
還有可能出現(xiàn)額外的高度間距码撰,需要用 MediaQuery.removePadding

MediaQuery.removePadding(
                      removeTop: true,
                      removeBottom: true,
                      context: context,
                      child: ListView.builder(
                          itemCount: 4,
                          shrinkWrap: true,
                          physics: NeverScrollableScrollPhysics(),
                          itemBuilder: (c, i) {
                            return ForumItem();
                          }),
                    ),

去除內(nèi)部高度渗柿。

三、showModalBottomSheet 高度限制,圓角問(wèn)題

解決方案:將整個(gè)文件拷貝進(jìn)項(xiàng)目朵栖。(建議重新命名颊亮,這樣導(dǎo)包的時(shí)候方便識(shí)別)
修改maxHeight,注釋掉即可

  @override
  BoxConstraints getConstraintsForChild(BoxConstraints constraints) {
    return BoxConstraints(
      minWidth: constraints.maxWidth,
      maxWidth: constraints.maxWidth,
      minHeight: 0.0,
      // maxHeight: isScrollControlled
      //   ? constraints.maxHeight
      //   : constraints.maxHeight,
    );
  }

圓角可通過(guò) shape: RoundedRectangleBorder( borderRadius: BorderRadius.only(topRight: Radius.circular(12.r), topLeft: Radius.circular(12.r))), 設(shè)置

四陨溅、TextFiled

1终惑、光標(biāo)問(wèn)題
如果設(shè)置了 controller.text ,并且在 onChanged 發(fā)生變化的時(shí)候 通過(guò) setState(){} 重新更新 text门扇,那就會(huì)使輸入框狀態(tài)發(fā)生變化雹有,光標(biāo)會(huì)回到初始位置。

  static textEditingController(String text) {
    return TextEditingController.fromValue(TextEditingValue(
        // 設(shè)置內(nèi)容
        text: text ?? "",
        // 保持光標(biāo)在最后
        selection: TextSelection.fromPosition(TextPosition(
            affinity: TextAffinity.downstream, offset: text == null ? 0 : text.length))));
  }

2臼寄、切換焦點(diǎn)
如果一個(gè)頁(yè)面有多個(gè)輸入框件舵,想實(shí)現(xiàn)輸入結(jié)束,點(diǎn)鍵盤(pán)的完成直接去下一個(gè)焦點(diǎn)輸入脯厨,
首先需要給各個(gè)輸入框設(shè)置 focusNode,
然后完成的回調(diào)事件是 onEditingComplete
通過(guò) FocusScope.of(context).requestFocus(_focusNodePwd); 設(shè)置新的焦點(diǎn)

3坑质、隱藏默認(rèn)下劃線
在 InputDecoration 里 有個(gè) border 將值設(shè)為 InputBorder.none 即可

五合武、系統(tǒng)狀態(tài)欄高度和底部操作欄高度適配問(wèn)題

頂部狀態(tài)欄高度可通過(guò) MediaQueryData.fromWindow(window).padding.top 獲取,
底部操作欄高度可通過(guò) MediaQueryData.fromWindow(window).padding.bottom 獲取涡扼,
在需要依附底部按鈕的地方稼跳,一定需要設(shè)置 margin bottom 操作欄高度,否則按鈕會(huì)被遮擋吃沪,在 iPhone 沒(méi)有 home 鍵的機(jī)型上可以看出來(lái)汤善。

六、分割線

flutter 提供了橫向和縱向的分割線組件可以直接使用
橫線 Divider 票彪,豎線VerticalDivider
在使用的時(shí)候外部需要用 Sizebox 包裹并且分別指定寬高


  SizedBox(
    width: 1.w,
    height: 100,
    child: VerticalDivider(
    color: Colors.red,
    width: 1.w,
    ),
  )

七红淡、監(jiān)聽(tīng) initState 加載完成事件

  void initState() {
    super.initState();
    //界面build完成后執(zhí)行回調(diào)函數(shù)
    WidgetsBinding.instance
        .addPostFrameCallback((_) => yourFunction(context)); //執(zhí)行yourFunction
  }

八、?? 等符號(hào)妙用

如果我們需要從一個(gè)對(duì)象取數(shù)據(jù)渲染降铸,假如數(shù)據(jù)為null在旱,那么就會(huì)報(bào)錯(cuò)一般的方法是判斷

data.str == null ? "" : data.str

但是在用了 dart 語(yǔ)法后,再這么寫(xiě)顯得很low推掸,并且也不夠美觀桶蝎,dart 提供了 ?? 方法,
其結(jié)果和上面的一樣

data.str ?? ""

還有一個(gè)是 ?. 它的意思是如果 data 為 null 就返回 null谅畅,不為 null 返回 data.str 結(jié)果

假如有多級(jí)對(duì)象嵌套登渣,如果不做判空處理那么 組件會(huì)報(bào)錯(cuò),一般是在進(jìn)行網(wǎng)絡(luò)請(qǐng)求后渲染數(shù)據(jù)毡泻,但是在更新數(shù)據(jù)前我們不想去做 loading 處理

Text(data?.info?.name ?? "");
//相當(dāng)于
Text(data != null && data.info != null && data.info.name != null
                                ? data.info.name
                                : ""),

這樣寫(xiě)是不是代碼簡(jiǎn)潔了很多胜茧?

九、字符串拼接

盡量少用 +號(hào)來(lái)拼接牙捉,dart 提供了 $${} 前者用于單個(gè)對(duì)象竹揍,后者用于多級(jí)數(shù)據(jù)敬飒,
而且如果使用 $ 拼接,無(wú)需對(duì) int double 類(lèi)型數(shù)據(jù)做 toString() 轉(zhuǎn)換芬位。

String a = "11111";

"$a${data.str}"
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末无拗,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子昧碉,更是在濱河造成了極大的恐慌英染,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件被饿,死亡現(xiàn)場(chǎng)離奇詭異四康,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)狭握,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)闪金,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人论颅,你說(shuō)我怎么就攤上這事哎垦。” “怎么了恃疯?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵漏设,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我今妄,道長(zhǎng)郑口,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任盾鳞,我火速辦了婚禮犬性,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘雁仲。我一直安慰自己仔夺,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布攒砖。 她就那樣靜靜地躺著缸兔,像睡著了一般。 火紅的嫁衣襯著肌膚如雪吹艇。 梳的紋絲不亂的頭發(fā)上惰蜜,一...
    開(kāi)封第一講書(shū)人閱讀 51,754評(píng)論 1 307
  • 那天,我揣著相機(jī)與錄音受神,去河邊找鬼抛猖。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的财著。 我是一名探鬼主播联四,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼撑教!你這毒婦竟也來(lái)了朝墩?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤伟姐,失蹤者是張志新(化名)和其女友劉穎收苏,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體愤兵,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡鹿霸,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了秆乳。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片懦鼠。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖屹堰,靈堂內(nèi)的尸體忽然破棺而出葛闷,到底是詐尸還是另有隱情,我是刑警寧澤双藕,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站阳仔,受9級(jí)特大地震影響忧陪,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜近范,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一嘶摊、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧评矩,春花似錦叶堆、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至蔗喂,卻和暖如春忘渔,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背缰儿。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工畦粮, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓宣赔,卻偏偏與公主長(zhǎng)得像预麸,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子儒将,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

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