日期选择器 Datepicker

datepicker 概览

日期选择器允许用户通过文本框输入一个日期,或用日历选取一个日期。它由一几个协同工作的组件、指令和日期的实现模块组成。

The datepicker allows users to enter a date either through text input, or by choosing a date from the calendar. It is made up of several components, directives and the date implementation module that work together.

Basic datepicker

日期选择器由一个文本输入框和一个日历弹出框组成,它们通过文本框上的 matDatepicker 联系起来。

A datepicker is composed of a text input and a calendar pop-up, connected via the matDatepicker property on the text input.

还有一个可选的日期选择器切换按钮,它给了用户一种弹出日期选择器的简易方式。

There is also an optional datepicker toggle button that gives the user an easy way to open the datepicker pop-up.

<input matInput [matDatepicker]="picker">
<mat-datepicker-toggle matSuffix [for]="picker"></mat-datepicker-toggle>
<mat-datepicker #picker></mat-datepicker>

当输入框作为 <mat-form-field> 的一部分时,也完全一样。 切换按钮可以很容易地作为输入框的前缀或后缀:

This works exactly the same with an input that is part of an <mat-form-field> and the toggle can easily be used as a prefix or suffix on the Material input:

<mat-form-field appearance="fill">
  <mat-label>Choose a date</mat-label>
  <input matInput [matDatepicker]="picker">
  <mat-datepicker-toggle matSuffix [for]="picker"></mat-datepicker-toggle>
  <mat-datepicker #picker></mat-datepicker>
</mat-form-field>

如果你要定制 mat-datepicker-toggle 中渲染的图标,可以使用 matDatepickerToggleIcon 指令:

If you want to customize the icon that is rendered inside the mat-datepicker-toggle, you can do so by using the matDatepickerToggleIcon directive:

Datepicker with custom icon

如果你希望用户选择一个日期范围而不是单个日期,可以使用 mat-date-range-inputmat-date-range-picker 组件。它们可以关联使用,类似于 mat-date-range-inputmat-datepicker

If you want your users to select a range of dates, instead of a single date, you can use the mat-date-range-input and mat-date-range-picker components. They work in tandem, similarly to the mat-datepicker and the basic datepicker input.

mat-date-range-input 组件要求为开始日期和结束日期分别提供两个 input 元素:

The mat-date-range-input component requires two input elements for the start and end dates, respectively:

<mat-date-range-input>
  <input matStartDate placeholder="Start date">
  <input matEndDate placeholder="End date">
</mat-date-range-input>

mat-date-range-picker 组件作为弹出式面板,用于选择日期。其工作方式和 mat-datepicker 相同,但允许用户多次选择:

The mat-date-range-picker component acts as the pop-up panel for selecting dates. This works in the same way as mat-datepicker, but allows the user to select multiple times:

<mat-date-range-picker #picker></mat-date-range-picker>

使用 rangePicker 属性把范围选择器和范围输入框联系起来:

Connect the range picker and range input using the rangePicker property:

<mat-date-range-input [rangePicker]="picker">
  <input matStartDate placeholder="Start date">
  <input matEndDate placeholder="End date">
</mat-date-range-input>

<mat-date-range-picker #picker></mat-date-range-picker>
Basic date range picker

mat-date-range-input 组件可以和来自 @angular/formsFormGroup 指令一起使用,它会把起始值和结束值组合在一起,并把它们作为一个组进行验证。

The mat-date-range-input component can be used together with the FormGroup directive from @angular/forms to group the start and end values together and to validate them as a group.

Date range picker forms integration

Selected range: { "start": null, "end": null }

<mat-datepicker>startView 属性可用来指定当首次打开日历时,应该使用哪个视图。 它可以是 month(月)、year(年)或 multi-year(多年)之一,默认情况下是月。

The startView property of <mat-datepicker> can be used to set the view that will show up when the calendar first opens. It can be set to month, year, or multi-year; by default it will open to month view.

此日历中打开的月份、年份或年份的范围,取决于当前是否选择了某个日期。如果选择了,它就会打开包含该日期的月份或年份。否则,它就打开包含当前日期的月份或年份。 这种行为可以用 <mat-datepicker>startAt 属性来改写。这种情况下,此日历将打开包含 startAt 日期的月份或年份。

The month, year, or range of years that the calendar opens to is determined by first checking if any date is currently selected, if so it will open to the month or year containing that date. Otherwise it will open to the month or year containing today's date. This behavior can be overridden by using the startAt property of <mat-datepicker>. In this case the calendar will open to the month or year containing the startAt date.

Datepicker start date

如果在 multi-year / year 视图中选择年 / 月时,输出属性 yearSelected / monthSelected 将会发出一个表示所选年 / 月的标准化日期。 这里 "标准化" 的意思是:对于年,它会设置为当年的一月一日;对于月,它会设置为当月的第一天。例如: 如果 <mat-datepicker> 配置为和 JavaScript 的原生 Date 对象协同工作,则当用户在 multi-year 视图中选中 2017 年时,yearSelected 将发出 new Date(2017, 0, 1)。 同样,如果用户在 year 视图中选中了二月,则 monthSelected 将会发出 new Date(2017, 1, 1)。而当打开日历时相关 <input> 的当前日期值会设置为某个类似 new Date(2017, MM, dd) 的值(这种情况下月和日是无关的)。

When a year or a month is selected in multi-year and year views respectively, the yearSelected and monthSelected outputs emit a normalized date representing the chosen year or month. By "normalized" we mean that the dates representing years will have their month set to January and their day set to the 1st. Dates representing months will have their day set to the 1st of the month. For example, if <mat-datepicker> is configured to work with javascript native Date objects, the yearSelected will emit new Date(2017, 0, 1) if the user selects 2017 in multi-year view. Similarly, monthSelected will emit new Date(2017, 1, 1) if the user selects February in year view and the current date value of the connected <input> was set to something like new Date(2017, MM, dd) when the calendar was opened (the month and day are irrelevant in this case).

注意,发出的值不会影响相关 <input> 的当前值,当前值只跟你在 month 视图中所做选的日期有关。 所以,如果最终用户在 multi-year 视图下选择了某一年后关闭了日历(比如通过按下 ESC 键),则由 yearSelected 发出的选定年份不会给相关 <input> 中的日期值带来任何变化。

Notice that the emitted value does not affect the current value in the connected <input>, which is only bound to the selection made in the month view. So if the end user closes the calendar after choosing a year in multi-view mode (by pressing the ESC key, for example), the selected year, emitted by yearSelected output, will not cause any change in the value of the date in the associated <input>.

下面的例子使用输出属性 yearSelectedmonthSelected 来模拟月和年的选择器(如果你对 MomentDateAdapterMAT_DATE_FORMATS 的用法还不熟,可以在稍后部分阅读它们以更好地理解该范例)。

The following example uses yearSelected and monthSelected outputs to emulate a month and year picker (if you're not familiar with the usage of MomentDateAdapter and MAT_DATE_FORMATS you can read more about them below in this document to fully understand the example).

Datepicker emulating a Year and month picker

Datepicker 的值类型取决于你提供的 DateAdapter 的类型。 比如,NativeDateAdapter 会直接使用普通的 JavaScript Date 对象;而使用 MomentDateAdapter 时,所有的值都会是 Moment.js 的实例。 这种适配器模式,可以让 Datepicker 组件借助自定义 DateAdapter 来处理日期的任何一种表示法。

The type of values that the datepicker expects depends on the type of DateAdapter provided in your application. The NativeDateAdapter, for example, works directly with plain JavaScript Date objects. When using the MomentDateAdapter, however, the values will all be Moment.js instances. This use of the adapter pattern allows the datepicker component to work with any arbitrary date representation with a custom DateAdapter. See Choosing a date implementation for more information.

根据所使用的 DateAdapter,日期选择器还可以自动重新序列化某些日期格式。例如:NativeDateAdapterMomentDateAdapter 都允许把 ISO 8601 字符串传给日期选择器, 并自动转换成合适的对象类型。 当直接把后端数据类型绑定到日期选择器时,这很方便。不过,日期选择器不接受用户格式的日期字符串(比如 "1/2/2017"), 因为它是有二义性的,它会根据执行代码的浏览器的时区设置不同而代表不同的日期。

Depending on the DateAdapter being used, the datepicker may automatically deserialize certain date formats for you as well. For example, both the NativeDateAdapter and MomentDateAdapter allow ISO 8601 strings to be passed to the datepicker and automatically converted to the proper object type. This can be convenient when binding data directly from your backend to the datepicker. However, the datepicker will not accept date strings formatted in user format such as "1/2/2017" as this is ambiguous and will mean different things depending on the locale of the browser running the code.

<input> 的其它类型一样,日期选择器也能和 @angular/forms 中的指令协同工作,比如 formGroupformControlngModel 等。

As with other types of <input>, the datepicker works with @angular/forms directives such as formGroup, formControl, ngModel, etc.

Datepicker selected value

当日期选择器弹出时,它会自动继承所附着的 mat-form-field 的调色板(primaryaccentwarn)。 如果你要为弹出框另行指定一个调色板,可以设置 mat-datepickercolor 属性。

The datepicker popup will automatically inherit the color palette (primary, accent, or warn) from the mat-form-field it is attached to. If you would like to specify a different palette for the popup you can do so by setting the color property on mat-datepicker.

Datepicker palette colors

有三个属性可以为日期选择器添加日期验证。前两个是 minmax 属性。除了对输入执行验证之外,这些属性还会禁用日期弹出框中相应值之前或之后的所有日期,并阻止用户将日历推进到包含 minmax 日期之外的 monthyear(取决于当前视图)。

There are three properties that add date validation to the datepicker input. The first two are the min and max properties. In addition to enforcing validation on the input, these properties will disable all dates on the calendar popup before or after the respective values and prevent the user from advancing the calendar past the month or year (depending on current view) containing the min or max date.

Datepicker with min & max validation

添加验证器的第二种方式是使用日期选择器输入框的 matDatepickerFilter 属性。 该属性接受一个 <D> => boolean 型的函数(这里的 <D> 是日期选择器所用的日期类型,参见选择一个日期实现类)。 如果结果是 true 则表示该日期是有效的,如果为 false 则表示无效。同样,这也会禁用日历上那些无效的日期。 不过,matDatepickerFilterminmax 之间有一个重要的差异 —— 如果过滤掉了特定时间点之前或之后的所有日期,并不会阻止用户把日历推进到无效的日期范围内。

The second way to add date validation is using the matDatepickerFilter property of the datepicker input. This property accepts a function of <D> => boolean (where <D> is the date type used by the datepicker, see Choosing a date implementation). A result of true indicates that the date is valid and a result of false indicates that it is not. Again this will also disable the dates on the calendar that are invalid. However, one important difference between using matDatepickerFilter vs using min or max is that filtering out all dates before or after a certain point, will not prevent the user from advancing the calendar past that point.

Datepicker with filter validation

在这个例子中(译注:这个例子有问题),用户可以回到 2005 年之前,但那之前的所有日期都是不可选取的。 但日历不能回到 2000 年之前。如果用户手动输入一个 min 之前或 max 之后或过滤掉的日期,该输入框就会发生有效性错误。

In this example the user can back past 2005, but all of the dates before then will be unselectable. They will not be able to go further back in the calendar than 2000. If they manually type in a date that is before the min, after the max, or filtered out, the input will have validation errors.

每个验证属性可以检查出不同的错误:

Each validation property has a different error that can be checked:

  • A value that violates the min property will have a matDatepickerMin error.违反 min 属性的值将给出 matDatepickerMin 错误。
  • A value that violates the max property will have a matDatepickerMax error.违反 max 属性的值将给出 matDatepickerMax 错误。
  • A value that violates the matDatepickerFilter property will have a matDatepickerFilter error.违反 matDatepickerFilter 属性的值将给出 matDatepickerFilter 错误。

输入框原生的 (input)(change) 事件只会因为用户和输入框元素的交互而触发;当用户在日历弹出框中选择日期时则不会触发。 因此,日期选择框的输入还支持 (dateInput)(dateChange) 事件。无论用户输入还是在弹出框中选择都会触发这两个事件。

The input's native (input) and (change) events will only trigger due to user interaction with the input element; they will not fire when the user selects a date from the calendar popup. Therefore, the datepicker input also has support for (dateInput) and (dateChange) events. These trigger when the user interacts with either the input or the popup.

每当用户正在输入或正在日历中点选日期时都会触发 (dateInput) 事件。 而当用户结束了输入(<input> 失去焦点)或在日历中选好了日期时,就会触发 (dateChange) 事件。

The (dateInput) event will fire whenever the value changes due to the user typing or selecting a date from the calendar. The (dateChange) event will fire whenever the user finishes typing input (on <input> blur), or when the user chooses a date from the calendar.

Datepicker input and change events

像任何标准的 <input> 一样,也可以通过添加 disabled 属性来禁用日期选择器的输入框。 默认情况下,<mat-datepicker><mat-datepicker-toggle> 将会从 <input> 中继承禁用状态,不过也可以通过设置日期选择器或开关元素的 disabled 属性来覆盖它。 如果你想禁用文本框却允许通过日历进行选取(或反之)时,这会很有用。

As with any standard <input>, it is possible to disable the datepicker input by adding the disabled property. By default, the <mat-datepicker> and <mat-datepicker-toggle> will inherit their disabled state from the <input>, but this can be overridden by setting the disabled property on the datepicker or toggle elements. This can be useful if you want to disable text input but allow selection via the calendar or vice-versa.

Disabled datepicker

默认情况下,单击日历中的某个日期会选择它并关闭日历弹出窗口。在某些情况下,这可能是不可取的,因为如果用户改变主意,用户就无法快速返回。如果你希望你的用户可以取消他们的选择,而必须明确接受他们已经选择的值,你可以在 <mat-datepicker> 中添加一个 <mat-datepicker-actions> 元素,内含带有 matDatepickerCancel 属性的 “Cancel” 按钮和带有 matDatepickerApply 属性的 “Apply” 按钮。这样就会让日期选择器只有在用户按下 “Apply” 的情况下才把值赋给数据模型,而按下 “Cancel” 则会关闭弹出窗口而不改变值。

By default, clicking on a date in the calendar will select it and close the calendar popup. In some cases this may not be desirable, because the user doesn't have a quick way of going back if they've changed their mind. If you want your users to be able to cancel their selection and to have to explicitly accept the value that they've selected, you can add a <mat-datepicker-actions> element inside <mat-datepicker> with a "Cancel" and an "Apply" button marked with the matDatepickerCancel and matDatepickerApply attributes respectively. Doing so will cause the datepicker to only assign the value to the data model if the user presses "Apply", whereas pressing "Cancel" will close popup without changing the value.

<mat-datepicker #datepicker>
  <mat-datepicker-actions>
    <button mat-button matDatepickerCancel>Cancel</button>
    <button mat-raised-button color="primary" matDatepickerApply>Apply</button>
  </mat-datepicker-actions>
</mat-datepicker>

此 actions 元素也支持 <mat-date-range-picker>,它叫做 <mat-date-range-picker-actions>,其按钮分别叫做 matDateRangePickerCancelmatDateRangePickerApply

The actions element is also supported for <mat-date-range-picker> where that it is called <mat-date-range-picker-actions> and the buttons are called matDateRangePickerCancel and matDateRangePickerApply respectively.

<mat-date-range-picker #rangePicker>
  <mat-date-range-picker-actions>
    <button mat-button matDateRangePickerCancel>Cancel</button>
    <button mat-raised-button color="primary" matDateRangePickerApply>Apply</button>
  </mat-date-range-picker-actions>
</mat-date-range-picker>
Datepicker action buttons

如果你的用户需要把他们当前正在选择的日期范围与另一个范围进行比较,你可以使用 comparisonStartcomparisonEnd 绑定来为 mat-date-range-input 提供比较范围。比较范围会在日历中静态呈现,但会改变颜色,以便指示哪些日期与用户选定的范围重叠。

If your users need to compare the date range that they're currently selecting with another range, you can provide the comparison range start and end dates to the mat-date-range-input using the comparisonStart and comparisonEnd bindings. The comparison range will be rendered statically within the calendar, but it will change colors to indicate which dates overlap with the user's selected range.

Date range picker comparison ranges

请注意,由于 Material Design 主题体系的限制,比较色和重叠色并非来自当前主题。可以使用 mat-date-range-colors mixin 来定制它们。

Note that comparison and overlap colors aren't derived from the current theme, due to limitations in the Material Design theming system. They can be customized using the mat-date-range-colors mixin.

mat-date-range-picker 支持自定义范围预览和选择的行为。为了自定义它,首先要创建一个实现 MatDateRangeSelectionStrategy 的类,然后通过 MAT_DATE_RANGE_SELECTION_STRATEGY 令牌提供该类。下面的例子使用这种范围选择策略来创建一个自定义范围选择器,它可以把用户限制在五天的范围内。

The mat-date-range-picker supports custom behaviors for range previews and selection. To customize this, you first create a class that implements MatDateRangeSelectionStrategy, and then provide the class via the MAT_DATE_RANGE_SELECTION_STRATEGY injection token. The following example uses the range selection strategy to create a custom range picker that limits the user to five-day ranges.

Date range picker with custom a selection strategy

正常情况下,日期选择器会在输入框下方打开一个弹出框。不过,这对于触屏设备很不理想,它们屏幕较小,并且需要更大的点击目标。 出于这个原因,<mat-datepicker> 有一个 touchUi 属性,它可以设置为 true 以便在大对话框中打开日历时启用更加友好的 UI。

The datepicker normally opens as a popup under the input. However this is not ideal for touch devices that don't have as much screen real estate and need bigger click targets. For this reason <mat-datepicker> has a touchUi property that can be set to true in order to enable a more touch friendly UI where the calendar opens in a large dialog.

Datepicker touch UI

日历弹出框可以使用 <mat-datepicker>openclose 方法进行程序化控制。 它还有一个 opened 属性来反应弹出框的状态。

The calendar popup can be programmatically controlled using the open and close methods on the <mat-datepicker>. It also has an opened property that reflects the status of the popup.

Datepicker open method

日期选择器的国际化配置包括四个方面:

Internationalization of the datepicker is configured via four aspects:

  1. 日期区域设置。

    The date locale.

  2. 日期选择器所能接受的日期对象实现。

    The date implementation that the datepicker accepts.

  3. 日期选择器所用的显示和解析格式。

    The display and parse formats used by the datepicker.

  4. 在日期选择器 UI 中使用的各种消息字符串。

    The message strings used in the datepicker's UI.

默认情况下,依赖注入令牌 MAT_DATE_LOCALE 将会使用来自 @angular/core 中的 LOCALE_ID 表示的区域代码。 如果你要覆盖它,可以为 MAT_DATE_LOCALE 令牌提供一个新值:

By default, the MAT_DATE_LOCALE injection token will use the existing LOCALE_ID locale code from @angular/core. If you want to override it, you can provide a new value for the MAT_DATE_LOCALE token:

@NgModule({
  providers: [
    {provide: MAT_DATE_LOCALE, useValue: 'en-GB'},
  ],
})
export class MyApp {}

还可以在运行期间使用 DateAdaptersetLocale 方法设置区域代码。

It's also possible to set the locale at runtime using the setLocale method of the DateAdapter.

Datepicker with different locale

日期选择器是和日期的具体实现无关的,也就是说它可以和多种不同的日期协同工作。不过,这也意味着开发者要确保为日期选择器提供恰当的实现来支持所选的日期实现。

The datepicker was built to be date implementation agnostic. This means that it can be made to work with a variety of different date implementations. However it also means that developers need to make sure to provide the appropriate pieces for the datepicker to work with their chosen implementation.

要做到这一点,最简单的方式是导入已提供的日期模块:

The easiest way to ensure this is to import one of the provided date modules:

MatNativeDateModule

Date type Date
Supported locales en-US
Dependencies None
Import from @angular/material/core

MatMomentDateModule

Date type Moment
Supported locales See project for details
Dependencies Moment.js
Import from @angular/material-moment-adapter

注意:MatNativeDateModule 基于 JavaScript 的原生 Date 对象所提供的功能,因此不适合多语言环境。原生 Date 对象最大的缺点是不能设置解析格式。我们强烈建议使用能和你所选的格式化 / 解析库协同使用的 MomentDateAdapter 或自定义 DateAdapter

Please note: MatNativeDateModule is based off the functionality available in JavaScript's native Date object. Thus it is not suitable for many locales. One of the biggest shortcomings of the native Date object is the inability to set the parse format. We highly recommend using the MomentDateAdapter or a custom DateAdapter that works with the formatting/parsing library of your choice.

这些模块包括了 DateAdapterMAT_DATE_FORMATS 的服务提供者。

These modules include providers for DateAdapter and MAT_DATE_FORMATS.

@NgModule({
  imports: [MatDatepickerModule, MatNativeDateModule],
})
export class MyApp {}

因为 DateAdapter 是一个泛型类,所以 MatDatepickerMatDatepickerInput 也要做成泛型的。 当使用这些类时(比如作为 ViewChild),你要包含与所用的 DateAdapter 实现相对应的泛型类。 比如:

Because DateAdapter is a generic class, MatDatepicker and MatDatepickerInput also need to be made generic. When working with these classes (for example as a ViewChild) you should include the appropriate generic type that corresponds to the DateAdapter implementation you are using. For example:

@Component({...})
export class MyComponent {
  @ViewChild(MatDatepicker) datepicker: MatDatepicker<Date>;
}
Datepicker that uses Moment.js dates

默认情况下,MomentDateAdapter 会在时区设置中指定的时区上创建日期。 你可以通过提供 MAT_MOMENT_DATE_ADAPTER_OPTIONS 并把它设置为 useUtc: true 来把默认行为修改为按照 UTC 格式解析日期。

By default the MomentDateAdapter creates dates in your time zone specific locale. You can change the default behaviour to parse dates as UTC by providing the MAT_MOMENT_DATE_ADAPTER_OPTIONS and setting it to useUtc: true.

@NgModule({
  imports: [MatDatepickerModule, MatMomentDateModule],
  providers: [
    {provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: {useUtc: true}}
  ]
})

默认情况下, MomentDateAdapter 会以宽容方式解析日期。这可能导致日期被错误解析。你可以通过提供 MAT_MOMENT_DATE_ADAPTER_OPTIONS 并把它设置为 strict: true 来修改默认行为以便严格解析日期

By default the MomentDateAdapter will parse dates in a forgiving way. This may result in dates being parsed incorrectly. You can change the default behaviour to parse dates strictly by providing the MAT_MOMENT_DATE_ADAPTER_OPTIONS and setting it to strict: true.

@NgModule({
  imports: [MatDatepickerModule, MatMomentDateModule],
  providers: [
    {provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: {strict: true}}
  ]
})

你还可以创建和应用所需的任何日期格式协同工作的自定义 DateAdapter。这可以通过创建 DateAdapter 的子类并把它作为 DateAdapter 的实现来完成。 你还要确保应用中所提供的 MAT_DATE_FORMATS 都是你的日期实现所能理解的格式。要了解关于 MAT_DATE_FORMATS 的更多信息,参见自定义解析和显示格式

It is also possible to create your own DateAdapter that works with any date format your app requires. This is accomplished by subclassing DateAdapter and providing your subclass as the DateAdapter implementation. You will also want to make sure that the MAT_DATE_FORMATS provided in your app are formats that can be understood by your date implementation. See Customizing the parse and display formatsfor more information about MAT_DATE_FORMATS.

@NgModule({
  imports: [MatDatepickerModule],
  providers: [
    {provide: DateAdapter, useClass: MyDateAdapter},
    {provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMATS},
  ],
})
export class MyApp {}

MAT_DATE_FORMATS 对象是一组日期选择器在解析和显示日期时所能使用的格式。这些格式都会传给 DateAdapter,所以你要确保这些格式对象能和应用中所用的 DateAdapter 兼容。

The MAT_DATE_FORMATS object is a collection of formats that the datepicker uses when parsing and displaying dates. These formats are passed through to the DateAdapter so you will want to make sure that the format objects you're using are compatible with the DateAdapter used in your app.

如果你要使用随 Angular Material 发布的 DateAdapter 之一和自己的 MAT_DATE_FORMATS,你可以导入 NativeDateModuleMomentDateModule。 这些模块都具有 "Mat" 前缀(MatNativeDateModuleMatMomentDateModule),除非它们不包含默认格式。比如:

If you want use one of the DateAdapters that ships with Angular Material, but use your own MAT_DATE_FORMATS, you can import the NativeDateModule or MomentDateModule. These modules are identical to the "Mat"-prefixed versions (MatNativeDateModule and MatMomentDateModule) except they do not include the default formats. For example:

@NgModule({
  imports: [MatDatepickerModule, NativeDateModule],
  providers: [
    {provide: MAT_DATE_FORMATS, useValue: MY_NATIVE_DATE_FORMATS},
  ],
})
export class MyApp {}
Datepicker with custom formats

要使用 MomentDateModule 的自定义格式,你可以从这里的文档中挑选解析格式,在这里的文档中挑选显示格式。

To use custom formats with the MomentDateModule you can pick from the parse formats documented here and the display formats documented here.

也可以支持多种解析格式。例如:

It is also possible to support multiple parse formats. For example:

@NgModule({
  imports: [MatDatepickerModule, MomentDateModule],
  providers: [
    {
      provide: MAT_DATE_FORMATS,
      useValue: {
        parse: {
          dateInput: ['l', 'LL'],
        },
        display: {
          dateInput: 'L',
          monthYearLabel: 'MMM YYYY',
          dateA11yLabel: 'LL',
          monthYearA11yLabel: 'MMMM YYYY',
        },
      },
    },
  ],
})
export class MyApp {}

你可以用自定义组件代替日历的头部(也就是包含视图切换器、向前和向后按钮的地方)。 这可以通过 <mat-datepicker>calendarHeaderComponent 属性来实现。 它接受一个组件类,并构建一个该组件的实例,将其用作日历头。

The header section of the calendar (the part containing the view switcher and previous and next buttons) can be replaced with a custom component if desired. This is accomplished using the calendarHeaderComponent property of <mat-datepicker>. It takes a component class and constructs an instance of the component to use as the header.

要想在自定义的日历头组件中和日历互动,你可以在它的构造函数中注入父 MatCalendar。 要确保你的日历头与日历保持同步,请订阅此日历的 stateChanges 事件,并把你的日历头组件标记为已更改的。

In order to interact with the calendar in your custom header component, you can inject the parent MatCalendar in the constructor. To make sure your header stays in sync with the calendar, subscribe to the stateChanges observable of the calendar and mark your header component for change detection.

Datepicker with custom calendar header

日期选择器中所用的多种文本字符串都可以由 MatDatepickerIntl 提供。 这些消息可以通过在应用的根模块中提供一个带有已翻译内容的子类来进行本地化。

The various text strings used by the datepicker are provided through MatDatepickerIntl. Localization of these messages can be done by providing a subclass with translated values in your application root module.

@NgModule({
  imports: [MatDatepickerModule, MatNativeDateModule],
  providers: [
    {provide: MatDatepickerIntl, useClass: MyIntl},
  ],
})
export class MyApp {}

如果你想把一个或多个 CSS 类应用到日历中的某些日期(比如突出显示一个假日),你可以使用输入属性 dateClass。它接受一个函数,将对日历中的每个日期调用该函数,并应用其返回的任何类。返回值可以是 ngClass 接受的任何值。

If you want to apply one or more CSS classes to some dates in the calendar (e.g. to highlight a holiday), you can do so with the dateClass input. It accepts a function which will be called with each of the dates in the calendar and will apply any classes that are returned. The return value can be anything that is accepted by ngClass.

Datepicker with custom date classes

MatDatepickerInputMatDatepickerToggle 会给原生输入框和开关按钮分别加上 aria-haspopup 属性,而它们触发的日历弹出框则会带有 role="dialog" 属性。

The MatDatepickerInput and MatDatepickerToggle directives add the aria-haspopup attribute to the native input and toggle button elements respectively, and they trigger a calendar dialog with role="dialog".

MatDatepickerIntl 包含一些要用作 aria-label 的字符串。日期选择器的输入框应该具有一个占位符或通过 aria-labelaria-labelledbyMatDatepickerIntl 提供一个有意义的标签。

MatDatepickerIntl includes strings that are used for aria-labels. The datepicker input should have a placeholder or be given a meaningful label via aria-label, aria-labelledby or MatDatepickerIntl.

日期选择器支持下列键盘快捷键:

The datepicker supports the following keyboard shortcuts:

快捷键

Shortcut

操作

Action

ALT + DOWN_ARROW

打开日历弹出框

Open the calendar pop-up

ESCAPE

关闭日历弹出框

Close the calendar pop-up

在月份视图中:

In month view:

快捷键

Shortcut

操作

Action

LEFT_ARROW

转到上一天

Go to previous day

RIGHT_ARROW

转到下一天

Go to next day

UP_ARROW

转到上周的同一天

Go to same day in the previous week

DOWN_ARROW

转到下周的同一天

Go to same day in the next week

HOME

转到本月初

Go to the first day of the month

END

转到本月末

Go to the last day of the month

PAGE_UP

转到上月的同一天

Go to the same day in the previous month

ALT + PAGE_UP

转到去年的同一天

Go to the same day in the previous year

PAGE_DOWN

转到下月的同一天

Go to the same day in the next month

ALT + PAGE_DOWN

转到明年的同一天

Go to the same day in the next year

ENTER

选择当前日期

Select current date

在年份视图中:

In year view:

快捷键

Shortcut

操作

Action

LEFT_ARROW

转到上月

Go to previous month

RIGHT_ARROW

转到下月

Go to next month

UP_ARROW

转到上一行(回退四个月)

Go up a row (back 4 months)

DOWN_ARROW

转到下一行(前进四个月)

Go down a row (forward 4 months)

HOME

转到今年的第一个月

Go to the first month of the year

END

转到今年的最后一月

Go to the last month of the year

PAGE_UP

转到去年的同一月

Go to the same month in the previous year

ALT + PAGE_UP

转到十年前的同一月

Go to the same month 10 years back

PAGE_DOWN

转到明年的同一月

Go to the same month in the next year

ALT + PAGE_DOWN

转到十年后的同一月

Go to the same month 10 years forward

ENTER

选择当前月份

Select current month

在多年视图中:

In multi-year view:

快捷键

Shortcut

操作

Action

LEFT_ARROW

转到去年

Go to previous year

RIGHT_ARROW

转到明年

Go to next year

UP_ARROW

转到上一行(后退四年)

Go up a row (back 4 years)

DOWN_ARROW

转到下一行(前进四年)

Go down a row (forward 4 years)

HOME

转到当前范围内的第一年

Go to the first year in the current range

END

转到当前范围内的最后一年

Go to the last year in the current range

PAGE_UP

后退 24 年

Go back 24 years

ALT + PAGE_UP

后退 240 年

Go back 240 years

PAGE_DOWN

前进 24 年

Go forward 24 years

ALT + PAGE_DOWN

前进 240 年

Go forward 240 years

ENTER

选择当前年份

Select current year

如果你没有提供日期选择器所需的全部可注入对象,就会抛出本错误。 最简单的解决方式是在应用的根模块中导入 MatNativeDateModuleMatMomentDateModule 模块。欲知详情,参见选择日期的一个实现

This error is thrown if you have not provided all of the injectables the datepicker needs to work. The easiest way to resolve this is to import the MatNativeDateModule or MatMomentDateModule in your application's root module. See Choosing a date implementation) for more information.

如果多个 <input> 视图(通过 matDatepicker 属性)获取同一个 <mat-datepicker> 的所有权,就会抛出本错误。 一个日期选择器只能和一个输入框相关联。

This error is thrown if more than one <input> tries to claim ownership over the same <mat-datepicker> (via the matDatepicker attribute on the input). A datepicker can only be associated with a single input.

如果没有给 <mat-datepicker> 关联任何 <input>,就会发生本错误。 要想把一个输入框和日期选择器关联起来,请创建一个到该日期选择器的模板引用,并把它赋值给输入框上的 matDatepicker 属性:

This error occurs if your <mat-datepicker> is not associated with any <input>. To associate an input with your datepicker, create a template reference for the datepicker and assign it to the matDatepicker attribute on the input:

<input [matDatepicker]="picker">
<mat-datepicker #picker></mat-datepicker>