注意:無特殊說明,Flutter版本及Dart版本如下:
創新互聯作為成都網站建設公司,專注成都網站建設、網站設計,有關成都企業網站建設方案、改版、費用等問題,行業涉及建筑動畫等多個領域,已為上千家企業服務,得到了客戶的尊重與認可。
- Flutter版本: 1.12.13+hotfix.5
- Dart版本: 2.7.0
當應用程序進行重要操作時經常需要用戶進行2次確認,以避免用戶的誤操作,比如刪除文件時,一般會彈出提示“是否要刪除當前文件”,用戶點擊確認后才會進行刪除操作,這時我們可以使用提示框(AlertDialog或者CupertinoAlertDialog)。
根據設計的不同,我們可以選擇Material風格的AlertDialog或者Cupertino(ios)風格的CupertinoAlertDialog,
Material風格基礎用法如下:
RaisedButton(
child: Text('切換'),
onPressed: () {
showDialog(
context: context,
builder: (context) {
return AlertDialog(
title: Text('提示'),
content: Text('確認刪除嗎?'),
actions: <Widget>[
FlatButton(child: Text('取消'),onPressed: (){},),
FlatButton(child: Text('確認'),onPressed: (){},),
],
);
});
},
)
Material風格效果:
Cupertino(ios)風格基礎用法如下:
RaisedButton(
child: Text('切換'),
onPressed: () {
showCupertinoDialog(
context: context,
builder: (context) {
return CupertinoAlertDialog(
title: Text('提示'),
content: Text('確認刪除嗎?'),
actions: <Widget>[
CupertinoDialogAction(child: Text('取消'),onPressed: (){},),
CupertinoDialogAction(child: Text('確認'),onPressed: (){},),
],
);
});
},
)
Cupertino(ios)風格效果如下:
showDialog
和
AlertDialog
配合使用展示Material風格對話框,
showCupertinoDialog
和
CupertinoAlertDialog
配合使用展示iOS風格對話框,
showCupertinoDialog
點擊空白處是無法退出對話框的,而
showDialog
點擊空白處默認退出對話框,
barrierDismissible
屬性控制點擊空白處的行為,用法如下:
showDialog(
barrierDismissible: false,
)
AlertDialog的屬性相對比較豐富,可以設置title樣式、content樣式、背景顏色、陰影值,設置是形狀:
AlertDialog(
title: Text('提示'),
content: Text('確認刪除嗎?'),
backgroundColor: Colors.lightBlueAccent,
elevation: 24,
shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(50)),
actions: <Widget>[
FlatButton(child: Text('取消'),onPressed: (){},),
FlatButton(child: Text('確認'),onPressed: (){},),
],
)
用戶點擊“取消”或者“確定”按鈕后退出對話框,App需要知道知道用戶選擇了哪個選項,用法如下:
RaisedButton(
child: Text('切換'),
onPressed: () async {
var result = await showDialog(
context: context,
builder: (context) {
return AlertDialog(
title: Text('提示'),
content: Text('確認刪除嗎?'),
actions: <Widget>[
FlatButton(
child: Text('取消'),
onPressed: () {
Navigator.of(context).pop('cancel');
},
),
FlatButton(
child: Text('確認'),
onPressed: () {
Navigator.of(context).pop('ok');
},
),
],
);
});
print('$result');
},
)
如果你覺得系統提供的這2個風格的對話框不夠個性,你可以試試SimpleDialog,用法和AlertDialog基本相同,如下:
SimpleDialog(
title: Text('提示'),
children: <Widget>[
Container(
height: 80,
alignment: Alignment.center,
child: Text('確認刪除嗎?'),
),
Divider(height: 1,),
FlatButton(
child: Text('取消'),
onPressed: () {
Navigator.of(context).pop('cancel');
},
),
Divider(height: 1,),
FlatButton(
child: Text('確認'),
onPressed: () {
Navigator.of(context).pop('ok');
},
),
],
)
效果如下:
如果你覺得這還是不夠個性,那可以祭出終極大招了,直接使用Dialog,Dialog可以定制任何對話框,只需將對話框的內容給child屬性:
Dialog(
child: MyDialog(),
);
當然一般情況下,系統提供的對話框就夠用了,這幾個對話框組件用法基本一樣,不同的地方僅僅是靈活性和使用簡易程度的不要,Dialog最靈活,但使用起來比AlertDialog復雜一些,AlertDialog使用起來非常簡單,但布局和基本樣式都已經固定好,不如Dialog靈活。
文章名稱:FlutterWidgets對話框-Dialog-創新互聯
文章轉載:http://m.newbst.com/article24/egice.html
成都網站建設公司_創新互聯,為您提供品牌網站制作、網站營銷、品牌網站設計、App設計、微信公眾號、品牌網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯