时间选择器是显示本地时区,如何改变,为了期望的时区?
答案 0 :(得分:1)
答案 1 :(得分:0)
Material-ui-pickers将利用您为应用程序配置的时区。如果您的moment
实例设置为使用特定时区-当您将其传递给选择器组件时,它将使用该时区并返回同一时区中的日期。
答案 2 :(得分:0)
如其他答案所述,Material-UI选择器使用第三方日期/时间库,您需要添加和配置它。
因此,您需要添加/添加以下内容:
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
更改为所需的timezone:
在使用选择器的组件中,您需要导入以下内容:
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>
注意:选取器支持其他日期/时间库,但有些不具有本地时区可配置性,例如date-fns