亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Flutter onTap中讓你脫穎而出的5條規(guī)則

 更新時(shí)間:2023年11月08日 10:12:06   作者:杭州程序員張張  
這篇文章主要為大家介紹了Flutter onTap中讓你脫穎而出的5條規(guī)則,小事情決定了你的熟練程度,這些小細(xì)節(jié)的有趣之處在于它們的豐富性

引言

小事情決定了你的熟練程度,這些小細(xì)節(jié)的有趣之處在于它們的豐富性。您將在代碼庫(kù)中的數(shù)百個(gè)位置遇到 onTap 事件。增強(qiáng)它們可以對(duì)代碼的可維護(hù)性和最終用戶體驗(yàn)產(chǎn)生重大的積極影響。

onTap 就是這樣一個(gè)微小但豐富的東西——我們?cè)诿總€(gè)屏幕上都使用它。這純粹是關(guān)于那些 onTap 事件:該做和不該做。

規(guī)則 1:小部件不應(yīng)實(shí)現(xiàn) onTap 邏輯

顧名思義,小部件是在屏幕上繪制的一塊 UI,它應(yīng)該對(duì)業(yè)務(wù)邏輯一無所知。如果需要,它可以將事件傳遞給其父級(jí)。做到這一點(diǎn)的最佳方法是使用函數(shù)作為構(gòu)造函數(shù)參數(shù)。

要點(diǎn):不要在小部件內(nèi)創(chuàng)建匿名函數(shù)來編寫業(yè)務(wù)邏輯。相反,甚至可以將 onTap 傳遞到小部件之外,并讓父級(jí)處理它。

// DON'T
class MyWidget extends StatelessWidget {
  @override
  Widget build(BuildContext context) => GestureDetector(
    onTap: () {
      debugPrint('MyWidget onTap called');
      fetchFromServer();
    },
    child: Container(
      width: 100,
      height: 100,
      color: Colors.orange,
    ),
  );
}
// DO
class MyWidget extends StatelessWidget {
  const MyWidget({this.onTap});
  final void Function()? onTap;
  @override
  Widget build(BuildContext context) => GestureDetector(
    onTap: onTap,
    child: Container(
      width: 100,
      height: 100,
      color: Colors.orange,
    ),
  );
}

規(guī)則 2:onTap 函數(shù)應(yīng)該可為 null

作為 UI 的一部分,小部件應(yīng)該是可重用的。不同的用例可能需要也可能不需要其 onTap 功能。因?yàn)樗嬖诘闹饕蚴窃谄聊簧侠L制而不是向其父級(jí)或控制器發(fā)送事件,所以它應(yīng)該能夠在有或沒有 onTap 事件的情況下存在。

要點(diǎn):使來自小部件的所有事件函數(shù)都可以為 null。

// DON'T
class MyWidget extends StatelessWidget {
  const MyWidget({required this.onTap});
  final void Function() onTap;
  @override
  Widget build(BuildContext context) => GestureDetector(
    onTap: onTap,
    child: Container(
      ...
    ),
  );
}
// DO
class MyWidget extends StatelessWidget {
  const MyWidget({this.onTap});
  final void Function()? onTap;
  @override
  Widget build(BuildContext context) => GestureDetector(
    onTap: onTap,
    child: Container(
      ...
    ),
  );
}

規(guī)則 3:UI 必須對(duì)邏輯一無所知,即使是指示性意義上的也不行

即使在使用最佳實(shí)踐之后,一個(gè)常見的錯(cuò)誤是命名指示業(yè)務(wù)邏輯的 UI 事件函數(shù)。銀行應(yīng)用程序中的小部件應(yīng)該不知道它屬于銀行應(yīng)用程序,并且只有足夠的數(shù)據(jù)來繪制它自己和它的孩子。換句話說,一個(gè)小部件應(yīng)該是美麗而愚蠢的。

要點(diǎn):命名 UI 事件函數(shù)以指示事件,而不是指示底層業(yè)務(wù)邏輯。將這樣的函數(shù)命名為 onTapRegisterButton() 比 register() 更好。

// DON'T
class MyScreen extends StatelessWidget {
  ...
  @override
  Widget build(BuildContext context) => Scaffold(
    body: MyWidget(
      onTap: controller.fetchData,
    );
  );
}
// DO
class MyScreen extends StatelessWidget {
  ...
  @override
  Widget build(BuildContext context) => Scaffold(
    body: MyWidget(
      onTap: controller.onTapMyWidget,
    );
  );
}
class MyScreenController {
  ...
  void onTapMyWidget() {
    _fetchData()
  }
  void _fetchData() {
    ...
  }
}

規(guī)則 4:盡可能傳遞模型

這一點(diǎn)不僅限于 UI,也適用于所有函數(shù)。每當(dāng)您需要傳遞一些數(shù)據(jù)作為參數(shù)時(shí),請(qǐng)盡量傳遞整個(gè)模型,而不僅僅是一個(gè) ID 或名稱。這是一個(gè)很好的做法,可以在將來業(yè)務(wù)邏輯擴(kuò)展或更改時(shí)盡量減少代碼更改。

要點(diǎn):將模型作為參數(shù)而不是 ID 傳遞給函數(shù)。

// DON'T
void onTapMyWidget(int subjectId) {
  ...
}
// DO
void onTapMyWidget(Subject subject) {
  ...
}

規(guī)則 5:始終指定 HitTestBehavior

使用 GestureDetector 進(jìn)行點(diǎn)擊時(shí),不要忘記將 behavior 添加到您的小部件中。此屬性指定點(diǎn)擊(點(diǎn)擊)如何傳播到子窗口小部件。在大多數(shù)情況下,您將使用 HitTestBehavior.opaque ,但我建議您應(yīng)該查看 flutter.dev 上的簡(jiǎn)短描述以了解情況。

要點(diǎn):通過指定小部件的點(diǎn)擊行為來絕對(duì)控制小部件的子部件。

class MyWidget extends StatelessWidget {
  ...
  @override
  Widget build(BuildContext context) => GestureDetector(
    onTap: onTap,
    behavior: HitTestBehavior.opaque,
    child: Container(
      ...
    ),
  );
}

以上就是Flutter onTap中讓你脫穎而出的5條規(guī)則的詳細(xì)內(nèi)容,更多關(guān)于Flutter onTap規(guī)則的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Android繪制旋轉(zhuǎn)動(dòng)畫方法詳解

    Android繪制旋轉(zhuǎn)動(dòng)畫方法詳解

    這篇文章主要介紹了Android如何采用RotateAnimation繪制一個(gè)旋轉(zhuǎn)動(dòng)畫,文中的實(shí)現(xiàn)方法講解詳細(xì),感興趣的小伙伴可以跟隨小編一起試一試
    2022-01-01
  • 獲取Android系統(tǒng)唯一識(shí)別碼的方法

    獲取Android系統(tǒng)唯一識(shí)別碼的方法

    這篇文章主要介紹了獲取Android系統(tǒng)唯一識(shí)別碼的方法,涉及通過編程獲取Android系統(tǒng)硬件設(shè)備標(biāo)識(shí)的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-10-10
  • Android超詳細(xì)講解組件LinearLayout的使用

    Android超詳細(xì)講解組件LinearLayout的使用

    LinearLayout又稱作線性布局,是一種非常常用的布局。正如它的名字所描述的一樣,這個(gè)布局會(huì)將它所包含的控件在線性方向上依次排列。既然是線性排列,肯定就不僅只有一個(gè)方向,這里一般只有兩個(gè)方向:水平方向和垂直方向
    2022-03-03
  • Android Studio如何獲取SQLite數(shù)據(jù)并顯示到ListView上

    Android Studio如何獲取SQLite數(shù)據(jù)并顯示到ListView上

    這篇文章主要介紹了Android Studio獲取SQLite數(shù)據(jù)并顯示到ListView上,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • 基于Android應(yīng)用中如何反饋Crash報(bào)告的詳解

    基于Android應(yīng)用中如何反饋Crash報(bào)告的詳解

    本篇文章是對(duì)在Android應(yīng)用中如何反饋Crash報(bào)告的詳細(xì)分析介紹。需要的朋友參考下
    2013-05-05
  • Android中使用Post請(qǐng)求的方法

    Android中使用Post請(qǐng)求的方法

    這篇文章主要介紹了Android中使用Post請(qǐng)求的方法,實(shí)例分析了Android中使用post請(qǐng)求的原理與具體實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • Android實(shí)現(xiàn)EditText添加下劃線

    Android實(shí)現(xiàn)EditText添加下劃線

    這篇文章主要為大家詳細(xì)介紹了Android如何實(shí)現(xiàn)給EditText添加下劃線,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • Android編程四大組件之Activity用法實(shí)例分析

    Android編程四大組件之Activity用法實(shí)例分析

    這篇文章主要介紹了Android編程四大組件之Activity用法,實(shí)例分析了Activity的創(chuàng)建,生命周期,內(nèi)存管理及啟動(dòng)模式等,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2016-01-01
  • Android實(shí)現(xiàn)列表元素動(dòng)態(tài)效果

    Android實(shí)現(xiàn)列表元素動(dòng)態(tài)效果

    本文將利用AnimatedList組件實(shí)現(xiàn)列表元素的一些動(dòng)態(tài)效果,例如添加元素時(shí)的漸現(xiàn)效果,刪除元素逐漸消失的效果等,感興趣的小伙伴可以了解一下
    2022-03-03
  • Android 7.0 SEAndroid app權(quán)限配置方法

    Android 7.0 SEAndroid app權(quán)限配置方法

    今天小編就為大家分享一篇Android 7.0 SEAndroid app權(quán)限配置方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07

最新評(píng)論