Средство выбора даты месяц / год не работает на iOS

#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>
);