注意:無特殊說明,F(xiàn)lutter版本及Dart版本如下:
- Flutter版本: 1.12.13+hotfix.5
- Dart版本: 2.7.0
應用程序有時候需要彈出消息提示用戶,比如‘網(wǎng)絡連接失敗’、‘下載成功’等提示,就像Android
等Toast,在Flutter中使用SnackBar組件,用法如下:
Scaffold.of(context).showSnackBar(SnackBar(
content: Text('老孟,一枚有態(tài)度的程序員'),
));
注意并不是在build方法中直接使用SnackBar組件,而是調(diào)用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),
));
效果如下:
通過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),
));
效果如下:
SnackBar的有2種彈出形式,默認是fixed
,直接在底部彈出,另一種是floating
,懸浮在底部,用法如下:
Scaffold.of(context).showSnackBar(SnackBar(
content: Row(
children: <Widget>[
Icon(Icons.check,color: Colors.green,),
Text('下載成功')],
),
behavior: SnackBarBehavior.floating,
));
floating
效果:
我們還可以對SnackBar增加行為組件,比如增加一個“知道了”按鈕,點擊“知道了”,消息馬上隱藏,用法如下:
Scaffold.of(context).showSnackBar(SnackBar(
content: Row(
children: <Widget>[
Icon(Icons.check,color: Colors.green,),
Text('下載成功')],
),
action: SnackBarAction(
label: '知道了',
onPressed: (){},
),
));
效果:
當短時間內(nèi)多次調(diào)用SnackBar方法時,SnackBar消息將會以隊列的形式一個一個的彈出,比如下面的代碼:
RaisedButton(
child: Text(
'點我,彈出SnackBar',
),
onPressed: () {
List.generate(10, (index){
Scaffold.of(context).showSnackBar(SnackBar(
content: Text('我是消息:$index'),
));
});
},
)
默認情況下每個顯示4秒,如果有10個,那么40秒內(nèi)會一直彈消息,體驗明顯不友好,我們希望的效果是如果有新的消息時,舊的都消息立刻消失,顯示新的消息,只需在彈出新的SnackBar時移除現(xiàn)在的SnackBar,
Scaffold.of(context).removeCurrentSnackBar();
Scaffold.of(context).showSnackBar(...);
當前題目:FlutterWidgets之SnackBar-創(chuàng)新互聯(lián)
當前鏈接:http://aaarwkj.com/article20/jopjo.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供自適應網(wǎng)站、全網(wǎng)營銷推廣、Google、網(wǎng)站改版、ChatGPT、品牌網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)