Flutter 时间控件修改

本文介绍了一个使用Flutter实现的日期选择器组件示例,该组件允许用户从指定范围内选择日期,并能根据用户的选择更新界面显示。示例中详细展示了如何初始化日期选择器、设置最小和最大可选日期、监听日期变化以及确认所选日期。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

String  selectItemValue=new DateTime.fromMillisecondsSinceEpoch(widget.birthday).toString().substring(0,10);

 FlatButton(
              onPressed: (){
                DateTime now= DateTime.parse("2000-01-01");
                DatePicker.showDatePicker(context,
                    showTitleActions: true,
                    minTime: DateTime(1950, 1, 1),
                    maxTime: DateTime(2020, 12,31), onChanged: (date) {
                      print('change $date');
                    }, onConfirm: (date) {
                      setState(() {
                        selectItemValue= '$date';
                      });
                      print('confirm $date');
                    },
                   //currentTime: DateTime.now(), locale: LocaleType.zh
                    currentTime:  DateTime.parse(selectItemValue), locale: LocaleType.zh //选择器上的时间为数据库读取的时间
           				// DateTime.parse() 将字符串类型的时间格式为时间类型
                );
              },
              //new DateTime.fromMicrosecondsSinceEpoch(listData[0]['birthday']).toString().substring(0,10)
              //listData[0]['birthday']==null?new DateTime.fromMicrosecondsSinceEpoch(listData[0]['birthday']).toString().substring(0,10):selectItemValue.toString().substring(0,10)
              child:
              selectItemValue==null?Container(
                  child:
                  Text('2000-01-01',style: TextStyle(color: Colors.black87,fontSize: 17),)//当没有选择的时候默认的值
              ):
              Container(
               // alignment: Alignment.centerRight,
                margin: EdgeInsets.fromLTRB(0.0, 0.0, 0.0, 0.0),
                width: 160,

                child:
                Text(selectItemValue.substring(0,10),textAlign:TextAlign.right,style: TextStyle(fontSize: 17,fontWeight: FontWeight.w400,color: Colors.black87),),
              ),
            ),
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值