Dart:Scalable Application Development
上QQ阅读APP看书,第一时间看更新

Working with dates

The ISO 8601 standard for dates is 'Year Month Day', and naturally, no country in the world uses this standard day to day! A typical variation is to have the month or day first, and then the separator character is used between digits in shorthand.

The intl package can help provide the appropriate format and translations for each language. Translation strings are required too as the name of the day or month may be required.

Date handling is implemented in the SlideShowApp class:

 import 'package:intl/date_symbol_data_local.dart';

A field is used to keep a reference to the active DateFormat object:

DateFormat slideDateFormatter;

We will consider how this formatter is initialized and kept up to date with the changes made to the users language.

Formatting for the locale

The locale for the date formatter will need to be updated whenever the interface language is changed:

    qs("#interfaceLang").onChange.listen((e){
      var lang = qs("#interfaceLang").value;
      setInterfaceLang(lang);
      langInterface = lang;
      initDefaultDate();
    });

When a locale has been requested, the appropriate DateFormat object needs to be created:

  initDefaultDate() {
    initializeDateFormatting(langInterface, null).then((d) {
      slideDateFormatter = new DateFormat.yMMMMEEEEd(langInterface);
    });
  }

Once this is in place, it is possible to change the interface language using the combo box and get a date in the correct format and language.

Formatting for the locale

As a final thought on this topic, most web applications are not nearly as dynamic in their choice of language. Typically, an interface language selection is a per user configuration option that is set up for each session when the user logs in.