首页 > 解决方案 > 如何更改 material-ui-pickers 时间选择器时区?

问题描述

时间选择器显示本地时区,如何将其更改为所需的时区?

标签: reactjsmaterial-uitimepickerluxon

解决方案


如其他答案中所述,Material-UI 选择器使用第三方日期/时间库,您需要添加和配置该库。

所以,你需要在 yarn/npm 添加这些:

yarn add moment
yarn add moment-timezones
yarn add @date-io/moment@1.x moment

在你App.js添加这个:

import moment from 'moment'

let launchMoment = require('moment')
require('moment-timezone')
moment.tz.setDefault('America/Los_Angeles')

您可以将 更改setDefault为您想要的时区

在您使用选择器的组件中,您需要导入这些:

import { MuiPickersUtilsProvider, KeyboardDatePicker } from '@material-ui/pickers'
import MomentUtils from '@date-io/moment'

您的选择器将如下所示:

<MuiPickersUtilsProvider utils={MomentUtils}>
          <KeyboardDatePicker
            disableToolbar
            variant="inline"
            format="ddd MMM Do"
            margin="normal"
            id="date-picker-inline"
            value={date}
  
            onChange={handleDateChange}
            KeyboardButtonProps={{
              'aria-label': 'change date'
            }}
           
          />
</MuiPickersUtilsProvider>

注意:Pickers 支持其他日期/时间库,但有些没有本地时区可配置性,例如date-fns


推荐阅读