如何使用FlutterWidgets調(diào)用SnackBar方法-創(chuàng)新互聯(lián)

基礎(chǔ)用法

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

丹東網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),丹東網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為丹東上1000+提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)公司要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的丹東做網(wǎng)站的公司定做!
Scaffold.of(context).showSnackBar(SnackBar(
    content: Text('老孟,一枚有態(tài)度的程序員'),
   ));

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

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

顯示的時(shí)間為1秒,content屬性不一定是文字,也可以是其他組件,比如顯示一個(gè)圖標(biāo)和文字:

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

效果如下:

如何使用Flutter Widgets調(diào)用SnackBar方法

通過shape屬性設(shè)置其形狀:

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調(diào)用SnackBar方法

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

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

floating效果:

如何使用Flutter Widgets調(diào)用SnackBar方法

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

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

效果:

如何使用Flutter Widgets調(diào)用SnackBar方法

瞬間多個(gè)彈出延遲問題

當(dāng)短時(shí)間內(nèi)多次調(diào)用SnackBar方法時(shí),SnackBar消息將會(huì)以隊(duì)列的形式一個(gè)一個(gè)的彈出,比如下面的代碼:

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

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

默認(rèn)情況下每個(gè)顯示4秒,如果有10個(gè),那么40秒內(nèi)會(huì)一直彈消息,體驗(yàn)明顯不友好,我們希望的效果是如果有新的消息時(shí),舊的都消息立刻消失,顯示新的消息,只需在彈出新的SnackBar時(shí)移除現(xiàn)在的SnackBar,

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

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

分享題目:如何使用FlutterWidgets調(diào)用SnackBar方法-創(chuàng)新互聯(lián)
分享鏈接:http://muchs.cn/article40/dsieho.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、虛擬主機(jī)營銷型網(wǎng)站建設(shè)、動(dòng)態(tài)網(wǎng)站品牌網(wǎng)站建設(shè)、網(wǎng)站排名

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作