26Flutter 日期 和時間戳/格式化日期庫/flutter異步/ 官方自帶日期組件showDatePicker、時間組件showTimePicker以及國際化

 

/*

1、Flutter日期和時間戳
日期轉換成時間戳
var now=newDateTime.now();
print(now.millisecondsSinceEpoch); //單位毫秒,13位時間戳。
時間戳轉換成日期:
var now=new DateTime.now();
var a=now.millisecondsSinceEpoch;//時間戳
print(DateTime.fromMillisecondsSinceEpoch(a));

2、Flutter第三方庫date_format的使用:
https://pub.dev/packages/date_format
3、調用flutter自帶日期組件和時間組:

*/
pubspec.yaml
  flutter_localizations:
    sdk: flutter

 

main.dartapp

import 'package:flutter/material.dart';
import 'package:flutter_demo/pages/Search.dart';
import 'routes/Routes.dart';
import 'package:flutter_localizations/flutter_localizations.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    // TODO: implement build
    return MaterialApp(
        localizationsDelegates: [
          GlobalMaterialLocalizations.delegate,
          GlobalWidgetsLocalizations.delegate
        ],
        supportedLocales: [
          const Locale('zh','CH'),
          const Locale('en','US')
        ],
        debugShowCheckedModeBanner: false, //去掉debug圖標:
        initialRoute: '/',
        onGenerateRoute: onGenerateRoute);
  }
}

 

DatePicker.dartless

import 'package:flutter/material.dart';
import 'package:date_format/date_format.dart';

class DatePickerDemo extends StatefulWidget {
  DatePickerDemo({Key key}) : super(key: key);
  _DatePickerDemoState createState() => _DatePickerDemoState();
}

class _DatePickerDemoState extends State<DatePickerDemo> {
  var now = DateTime.now();
  DateTime _nowDate = DateTime.now();
  var _nowTime=TimeOfDay(hour: 12,minute: 20);
  // String time;
  _showDatePicker() async {
    // showDatePicker(
    //   context: context,
    //   initialDate: _nowDate,
    //   firstDate: DateTime(1980),
    //   lastDate: DateTime(2100)
    // ).then((result){
    //   print(result);
    // });

    var result = await showDatePicker(
        context: context,
        initialDate: _nowDate,
        firstDate: DateTime(1980),
        lastDate: DateTime(2100),
        locale: Locale('zh')
    );

    print(result);
    setState(() {
      this._nowDate = result;
    });
  }

  _showTimePicker() async{
    var result=await showTimePicker(
      context: context,
      initialTime:_nowTime
    );
    setState(() {
      this._nowTime=result;
    });
  }
  @override
  void initState() {
    // TODO: implement initState
    super.initState();
    // print(778899);
    // //
    // print(now.millisecondsSinceEpoch); //1568786998995
    // print(DateTime.fromMillisecondsSinceEpoch(1568786998995)); //2019-09-18 14:09:58.995

    // print(formatDate(DateTime.now(),[yyyy,'年',mm,'月',dd]));
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(title: Text('DatePicker')),
        body: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Row(
              children: <Widget>[
                InkWell(
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.center,
                    children: <Widget>[
                      Text("${formatDate(_nowDate, [
                        yyyy,
                        '',
                        mm,
                        '',
                        dd,
                        ''
                      ])}"),
                      Icon(Icons.arrow_drop_down)
                    ],
                  ),
                  onTap: _showDatePicker,
                ),
                InkWell(
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.center,
                    children: <Widget>[
                      Text("${_nowTime.format(context)}"),
                      Icon(Icons.arrow_drop_down)
                    ],
                  ),
                  onTap: _showTimePicker,
                )
              ],
            )
          ],
        ));
  }
}
相關文章
相關標籤/搜索