当前位置:网站首页>A brief introduction to the showDatePicker method of the basic components of Flutter
A brief introduction to the showDatePicker method of the basic components of Flutter
2022-07-31 03:19:00 【A soybean】
浅识Flutter 基本组件之showDatePicker 方法
showDatePicker ()method is used to pop up a date picker dialog,The dialog has a system default style,也可以通过builderProperties to set custom styles,Its common properties and function descriptions are as follows.
| 属性名 | 类型 | 功能说明 |
|---|---|---|
| context | BuildContext | 设置BuildContext |
| initialDate | DateTime | Sets the default date when the date picker is opened |
| firstDate | DateTime | Sets the start date that can be selected by the date picker |
| lastDate | DateTime | Sets the date picker selectable end date |
| local | Locale | 设置国际化,默认英文 |
| selectableDayPredicate | bool | Sets an optional date for the date picker |
| builder | Widget | Set the date picker theme.Title bar and other styles |
例如,页面上有一个Text组件和一个RaiseButton组件,当点击RaiseButton组件后,弹出日期选择器,After selecting a date on the date picker,将日期显示在Text组件上.
showdata(context) {
showDatePicker(
context: context,
initialDate: DateTime.now(),
lastDate: DateTime.now(),
firstDate: DateTime(1900, 01, 01));
}
FloatingActionButton(
onPressed: () {
showdata(context);
},
backgroundColor: Colors.white,
child: Icon(Icons.watch, color: Colors.grey),
)


The selected date will be displayed
String data = DateTime.now().toString().substring(0,10);
Future<DateTime?> showData(context) async{
// async异步调用的方法 需要等showDatePicker执行完 加上await
DateTime? d =await showDatePicker(
context: context,
initialDate: DateTime.now(),
lastDate: DateTime.now(),
firstDate: DateTime(1900, 01, 01));
/*The selected date will be displayed*/
setState(() {
data= d.toString().substring(0,10);
});
}


完整代码
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
class zhucepage extends StatefulWidget {
@override
State<StatefulWidget> createState() {
return MyState();
}
}
class MyState extends State {
List flag = [false, false, false];
List select = ['皇后', '华妃', '甄嬛'];
bool isChecked = false;
//Define a method that pops up a datepickershowdata
String data = DateTime.now().toString().substring(0,10);
Future<DateTime?> showData(context) async{
// async异步调用的方法 需要等showDatePicker执行完 加上await
DateTime? d =await showDatePicker(
context: context,
initialDate: DateTime.now(),
lastDate: DateTime.now(),
firstDate: DateTime(1900, 01, 01));
/*The selected date will be displayed*/
setState(() {
data= d.toString().substring(0,10);
});
}
// showData(context) {
// var d=showDatePicker(
// context: context,
// initialDate: DateTime.now(),
// lastDate: DateTime.now(),
// firstDate: DateTime(1900, 01, 01));
// /*The selected date will be displayed*/
// setState(() {
// data= d.toString().substring(0,10);
// });
//
// }
@override
Widget build(BuildContext context) {
Row row = Row(
children: <Widget>[
Text('选择你的阵营: '),
Text(select[0]),
Checkbox(
value: flag[0],
onChanged: (value) {
//setState更新值
setState(() {
flag[0] = value!;
});
},
),
Text(select[1]),
Checkbox(
value: flag[1],
onChanged: (value) {
//setState更新值
setState(() {
flag[1] = value!;
});
},
),
Text(select[2]),
Checkbox(
value: flag[2],
onChanged: (value) {
//setState更新值
setState(() {
flag[2] = value!;
});
},
),
],
);
/*创建多个CheckboxListTile*/
Column column = Column(
children: <Widget>[
CheckboxListTile(
value: this.isChecked,
/*设置主标题组件*/
title: Text(
'全选',
style: TextStyle(color: Colors.red),
),
/*设置副标题组件*/
subtitle: Text('全选表示自成一派'),
/*设置显示的小组件,与□所在位置相反*/
secondary: Icon(Icons.flag),
/*调整复选框和图标的位置*/
controlAffinity: ListTileControlAffinity.leading,
onChanged: (bool? value) {
setState(() {
isChecked = value!;
for (int i = 0; i < flag.length; i++) {
flag[i] = isChecked;
}
});
},
),
CheckboxListTile(
title: Text(select[0]),
subtitle: Text('堕胎小分队'),
secondary: Icon(Icons.info),
/*调整复选框和图标的位置*/
controlAffinity: ListTileControlAffinity.leading,
value: flag[0],
onChanged: (value) {
setState(() {
flag[0] = value;
});
}),
CheckboxListTile(
title: Text(select[1]),
subtitle: Text('世兰好苦队'),
secondary: Icon(Icons.info),
/*调整复选框和图标的位置*/
controlAffinity: ListTileControlAffinity.leading,
value: flag[1],
onChanged: (value) {
setState(() {
flag[1] = value;
});
}),
CheckboxListTile(
title: Text(select[2]),
subtitle: Text('莞莞类卿队'),
secondary: Icon(Icons.info),
/*调整复选框和图标的位置*/
controlAffinity: ListTileControlAffinity.leading,
value: flag[2],
onChanged: (value) {
setState(() {
flag[2] = value;
});
}),
// Row(children: <Widget>[
// Text("Choose the day you enter the palace: "),
// Text(data),
// ]),
/*点击一个按钮,The date selection dialog box pops up*/
Row(children: <Widget>[
Text("Choose the day you enter the palace: "),
Text(data+' '),
FloatingActionButton(
onPressed: () {
showData(context);
},
backgroundColor: Colors.white,
child: Icon(Icons.watch, color: Colors.grey ),
),
]),
],
);
return Scaffold(
appBar: AppBar(
title: Text('用户注册'),
centerTitle: true,
),
body: column,
floatingActionButton: FloatingActionButton(
onPressed: () {
String info = "你选择的阵营是:";
for (int i = 0; i < flag.length; i++) {
if (flag[i]) {
/*如果选项被选中*/
info = info + select[i] + ' ';
}
}
print(info);
},
tooltip: 'Increment',
child: Icon(Icons.save),
),
floatingActionButtonLocation:
FloatingActionButtonLocation.centerFloat, //浮标的位置
);
}
}
边栏推荐
- some of my own thoughts
- Mysql 45 study notes (twenty-four) MYSQL master-slave consistency
- SQL 面试用题(重点)
- 点云DBSCAN聚类(MATLAB,非内置函数)
- 一份高质量的测试用例如何养成?
- 想从手工测试转岗自动化测试,需要学习哪些技能?
- addressable in Golang
- 【Cocos Creator 3.5】缓动系统停止所有动画
- 7年经验,功能测试工程师该如何一步步提升自己的能力呢?
- False positives and false negatives in testing are equally worthy of repeated corrections
猜你喜欢
随机推荐
冒泡排序、选择排序、直接插入排序、二分法查找
顺序表的实现
Web container and IIS --- Middleware penetration method 1
接口测试关键技术
LeetCode中等题之分数加减运算
[C language] Three-pointed chess (classic solution + list diagram)
立足本土,链接全球 | 施耐德电气“工业SI同盟”携手伙伴共赴未来工业
【动态规划】连续子数组的最大和
Mysql 45讲学习笔记(二十四)MYSQL主从一致
Thesis framework of the opening report
Detailed explanation of TCP (2)
STM32 problem collection
【异常】The field file exceeds its maximum permitted size of 1048576 bytes.
Annotation usage meaning
els 方块向右移
MP使用时的几个常见报错
LeetCode每日一练 —— 138. 复制带随机指针的链表
[Compilation principle] Lexical analysis program design principle and implementation
【Exception】The field file exceeds its maximum permitted size of 1048576 bytes.
Chapter 9 SVM Practice








