Flutter Widgets 之 SnackBar

mengqingdong1發表於2020-03-01

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 Widgets 之 SnackBar

相關文章