#javascript #html #css #reactjs #react-day-picker
#javascript #HTML #css #reactjs #реагировать-средство выбора дня
Вопрос:
Я использую react-day-picker
пакет для выбора даты с включенными реквизитами год / месяц. Однако выпадающий список год / месяц не работает должным образом в мобильных браузерах iOS:
import React from 'react';
import ReactDOM from "react-dom";
import DayPickerInput from 'react-day-picker/DayPickerInput';
import 'react-day-picker/lib/style.css';
const currentYear = new Date().getFullYear();
const fromMonth = new Date(currentYear, 0);
const toMonth = new Date(currentYear 10, 11);
function YearMonthForm({ date, localeUtils, onChange }) {
const months = localeUtils.getMonths();
const years = [];
for (let i = fromMonth.getFullYear(); i <= toMonth.getFullYear(); i = 1) {
years.push(i);
}
const handleChange = function handleChange(e) {
const { year, month } = e.target.form;
onChange(new Date(year.value, month.value));
};
return (
<form className="DayPicker-Caption">
<select name="month" onChange={handleChange} value={date.getMonth()}>
{months.map((month, i) => (
<option key={month} value={i}>
{month}
</option>
))}
</select>
<select name="year" onChange={handleChange} value={date.getFullYear()}>
{years.map(year => (
<option key={year} value={year}>
{year}
</option>
))}
</select>
</form>
);
}
export default class Example extends React.Component {
constructor(props) {
super(props);
this.handleYearMonthChange = this.handleYearMonthChange.bind(this);
this.state = {
month: fromMonth,
};
}
handleYearMonthChange(month) {
this.setState({ month });
}
render() {
const dayPickerProps = {
month: this.state.month,
fromMonth: fromMonth,
toMonth: toMonth,
captionElement: ({ date, localeUtils }) => (
<YearMonthForm
date={date}
localeUtils={localeUtils}
onChange={this.handleYearMonthChange}
/>
)
};
return (
<div className="YearNavigation">
<DayPickerInput
showOverlay={true}
dayPickerProps={dayPickerProps}
/>
</div>
);
}
}
ReactDOM.render(<Example />, document.getElementById("root"));
Вы можете посмотреть демонстрационную версию по этой ссылке (необходимо открыть ее на устройстве iOS):
https://codesandbox.io/s/0y84wrp8mn
Есть ли обходной путь для этого?
Комментарии:
1. Теперь проверьте это » codesandbox.io/s/rrkovxzzp4 «это должно сработать
2. @ShivaKumarN по-прежнему не работает.
3. в safari, который работает нормально
4. @ShivaKumarN не работает ни в safari Mobile, ни в chrome.
5. Хорошо, просто попробуйте: добавьте #’npm install —save babel-polyfill’ и просто импортируйте его в начальную точку входа вашего проекта, например App.js/index.js #импортировать «babel-polyfill»
Ответ №1:
проблема в том, что для keepFocus по умолчанию установлено значение true. Измените свой метод рендеринга, подобный этому, в вашем компоненте Example (keepFocus={false}):
return (
<div className="YearNavigation">
<DayPickerInput
showOverlay={true}
keepFocus={false}
dayPickerProps={dayPickerProps}
/>
</div>
);