【问题标题】:Multi Language React DatePicker多语言反应日期选择器
【发布时间】:2021-09-23 19:53:44
【问题描述】:

我正在尝试翻译组件 React DatePicker。但是,我在尝试执行此操作时遇到错误。

到目前为止我的代码:

import DatePicker, { registerLocale } from 'react-datepicker';

const MONTHSDATE = ['Janeiro', 'Fevereiro', 'Março', 'Abril', 'Maio', 'Junho', 'Julho', 'Agosto', 'Setembro', 'Outubro', 'Novembro', 'Dezembro'];
const DAYSDATE = ['Domingo', 'Segunda', 'Terça', 'Quarta', 'Quinta', 'Sexta', 'Sábado'];

registerLocale('ptBR', {
        localize: {
            month: n => MONTHSDATE[n],
            day: n => DAYSDATE[n]
        },
        formatLong: {}
    });
    

<DatePicker
    selected={realizedDateFrom}
    onChange={(date) => setRealizedDateFrom(date)}
    placeholderText={translate.t("activity_report_realized_from")}
    className="MuiInputBase-root MuiFilledInput-root activity-report-datepicker"
    dateFormat={'dd/MM/yyyy'}
    showMonthDropdown
    showYearDropdown
    formatWeekDay={nameOfDay => nameOfDay.substr(0, 3)}
    locale={translate.t("datapicker_translate")} //using translate getting word 'ptBR' for portuguese and 'en' for english
/>

当我更改语言时,当我从日历中选择日期时,此代码运行良好...

但是当我尝试从键盘写入/输入时出现此错误

这个组件的源代码是 --> 项目:https://github.com/Hacker0x01/react-datepicker

【问题讨论】:

    标签: javascript reactjs


    【解决方案1】:

    您可以将date-fns 用于ptBR。 (基本上,错误是因为日历需要的翻译比您编写的要多)。

    因此,建议从date-fns 使用它们,例如:

    import React from "react";
    import DatePicker from "react-datepicker";
    import { registerLocale } from "react-datepicker";
    
    import "react-datepicker/dist/react-datepicker.css";
    import { en, ptBR } from "date-fns/locale";
    
    registerLocale("ptBR", ptBR);
    registerLocale("en", en);
    
    export default function App() {
      const [language, setLanguage] = React.useState("ptBR");
    
      return (
        <div className="App">
          <h3>Change the Language ({language})</h3>
          <DatePicker locale={language} />
          <button onClick={() => setLanguage("ptBr")}>ptBr</button>
          <button onClick={() => setLanguage("en")}>eng</button>
        </div>
      );
    }
    

    示例在 CodeSandbox 上运行:https://codesandbox.io/s/empty-browser-yfvg7?file=/src/App.js

    【讨论】:

    • 感谢您的回答,但我正在尝试为多语言做这项工作,特别是英语和葡萄牙语。您的答案有效,但仅限葡萄牙语
    • @RafaelBreno 我刚刚用两种语言更新了答案。
    • 再次感谢@joseglego 我明白了。但我想要的是同一个组件可以改变你自己的语言。在您的解决方案中,您只需使用英语创建另一个组件。我的意思是我想要的只是一个组件 DatePicker 并且能够更改您的语言。
    • @RafaelBreno 再编辑一次,你可以在第三个日历中更改 :)
    • 谢谢我的主……你救了我的命。但我仍然有一个问题,我怎么能像我已经放的那样把几个月和几天放出来
    猜你喜欢
    • 1970-01-01
    • 2021-01-11
    • 1970-01-01
    • 1970-01-01
    • 2023-01-24
    • 2020-10-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多