91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Flutter Widgets 之 SnackBar

發布時間:2020-08-03 00:49:57 來源:網絡 閱讀:180 作者:mengqingdon 欄目:移動開發

Flutter Widgets 之 SnackBar

注意:無特殊說明,Flutter版本及Dart版本如下:

  • Flutter版本: 1.12.13+hotfix.5
  • Dart版本: 2.7.0

基礎用法

應用程序有時候需要彈出消息提示用戶,比如‘網絡連接失敗’、‘下載成功’等提示,就像Android
等Toast,在Flutter中使用SnackBar組件,用法如下:

Scaffold.of(context).showSnackBar(SnackBar(
      content: Text('老孟,一枚有態度的程序員'),
    ));

注意并不是在build方法中直接使用SnackBar組件,而是調用Scaffold.of(context).showSnackBar方法,消息會在底部彈出并顯示一段時間,默認顯示4秒,然后彈出,我們可以設置其顯示的時間:

Scaffold.of(context).showSnackBar(SnackBar(
      duration: Duration(seconds: 1),
    ));

顯示的時間為1秒,content屬性不一定是文字,也可以是其他組件,比如顯示一個圖標和文字:

Scaffold.of(context).showSnackBar(SnackBar(
      content: Row(
        children: <Widget>[
          Icon(Icons.check,color: Colors.green,),
          Text('下載成功')],
      ),
      duration: Duration(seconds: 1),
    ));

效果如下:

Flutter Widgets 之 SnackBar

通過shape屬性設置其形狀:

Scaffold.of(context).showSnackBar(SnackBar(
      content: Row(
        children: <Widget>[
          Icon(Icons.check,color: Colors.green,),
          Text('下載成功')],
      ),
      shape: RoundedRectangleBorder(
        borderRadius: BorderRadius.all(Radius.circular(50))
      ),
      duration: Duration(seconds: 1),
    ));

效果如下:

Flutter Widgets 之 SnackBar

SnackBar的有2種彈出形式,默認是fixed,直接在底部彈出,另一種是floating,懸浮在底部,用法如下:

Scaffold.of(context).showSnackBar(SnackBar(
      content: Row(
        children: <Widget>[
          Icon(Icons.check,color: Colors.green,),
          Text('下載成功')],
      ),
      behavior: SnackBarBehavior.floating,
    ));

floating效果:

Flutter Widgets 之 SnackBar

我們還可以對SnackBar增加行為組件,比如增加一個“知道了”按鈕,點擊“知道了”,消息馬上隱藏,用法如下:

Scaffold.of(context).showSnackBar(SnackBar(
      content: Row(
        children: <Widget>[
          Icon(Icons.check,color: Colors.green,),
          Text('下載成功')],
      ),
      action: SnackBarAction(
        label: '知道了',
        onPressed: (){},
      ),
    ));

效果:

Flutter Widgets 之 SnackBar

瞬間多個彈出延遲問題

當短時間內多次調用SnackBar方法時,SnackBar消息將會以隊列的形式一個一個的彈出,比如下面的代碼:

RaisedButton(
          child: Text(
            '點我,彈出SnackBar',
          ),
          onPressed: () {

            List.generate(10, (index){
              Scaffold.of(context).showSnackBar(SnackBar(
                content: Text('我是消息:$index'),
              ));
            });
          },
        )

默認情況下每個顯示4秒,如果有10個,那么40秒內會一直彈消息,體驗明顯不友好,我們希望的效果是如果有新的消息時,舊的都消息立刻消失,顯示新的消息,只需在彈出新的SnackBar時移除現在的SnackBar,

Scaffold.of(context).removeCurrentSnackBar();
Scaffold.of(context).showSnackBar(...);

更多相關閱讀:

  • Flutter系列文章總覽
  • Flutter Widgets 之 Expanded和Flexible
  • Flutter Widgets 之 AnimatedList
  • Flutter Widgets 之 SliverAppBar
如果這篇文章有幫助到您,希望您來個“贊”并關注我的公眾號,非常謝謝。

Flutter Widgets 之 SnackBar

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

辽宁省| 莎车县| 洛南县| 新安县| 英山县| 十堰市| 瑞昌市| 青冈县| 舟曲县| 聊城市| 通州区| 原阳县| 于田县| 乾安县| 江永县| 游戏| 凤阳县| 万源市| 灵丘县| 柳林县| 石城县| 山东省| 崇阳县| 衡山县| 老河口市| 武宁县| 土默特右旗| 鹤岗市| 安庆市| 蒙城县| 阿巴嘎旗| 泾源县| 大冶市| 中西区| 汾阳市| 乃东县| 滕州市| 河间市| 板桥市| 绩溪县| 平昌县|