真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

基礎(chǔ)用法

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

成都創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都做網(wǎng)站、網(wǎng)站建設(shè)、黎平網(wǎng)絡(luò)推廣、微信小程序、黎平網(wǎng)絡(luò)營銷、黎平企業(yè)策劃、黎平品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供黎平建站搭建服務(wù),24小時服務(wù)熱線:028-86922220,官方網(wǎng)址:www.cdcxhl.com

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

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

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

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

Scaffold.of(context).showSnackBar(SnackBar(
      content: Row(
        children: [
          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: [
          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種彈出形式,默認是fixed,直接在底部彈出,另一種是floating,懸浮在底部,用法如下:

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

floating效果:

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

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

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

效果:

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

瞬間多個彈出延遲問題

當(dāng)短時間內(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(...);

當(dāng)前文章:如何使用FlutterWidgets調(diào)用SnackBar方法
文章鏈接:http://weahome.cn/article/pjosjd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部