/ Date Components

Date Components

各种日期组件。

@gravity-ui/date-components · npm package CI storybook

安装

npm install react react-dom @gravity-ui/uikit @gravity-ui/date-components @gravity-ui/date-utils

用法

import {createRoot} from 'react-dom/client';
import {DatePicker} from '@gravity-ui/date-components';
import {ThemeProvider} from '@gravity-ui/uikit';

import '@gravity-ui/uikit/styles/styles.css';

function App() {
  return (
    <ThemeProvider>
      <h1>DatePicker</h1>
      <form>
        <label forHtml="date-picker">Date:</label>
        <DatePicker id="date-picker" name="date" />
      </form>
    </ThemeProvider>
  );
}

const root = createRoot(document.getElementById('root'));
root.render(<App />);

本地化

import {settings} from '@gravity-ui/date-utils';

// 加载应用程序将使用的日期区域设置。
settings.loadLocale('ru');

function App() {
  return (
    // 设置组件使用的语言。
    <ThemeProvider lang="ru">
      <h1>DatePicker</h1>
      <form>
        <label forHtml="date-picker">日期:</label>
        <DatePicker id="date-picker" name="date" />
      </form>
    </ThemeProvider>
  );
}

如果您的应用程序支持语言切换,请在应用程序首次加载时预加载所有支持的区域设置,或者在切换语言之前加载区域设置:

// 预加载区域设置
settings.loadLocale('ru');
settings.loadLocale('nl');

const root = createRoot(document.getElementById('root'));
root.render(<App />);

// 或者按需加载。

function App() {
  const [lang, setLang] = React.useState('en');

  const handleLangChange = (newLang) => {
    settings.loadLocale(newLang).then(() => {
      setLang(newLang);
    });
  };

  return <ThemeProvider lang={lang}>...</ThemeProvider>;
}

这些组件提供英语和俄语的翻译。要添加其他语言的翻译,请使用 @gravity-ui/uikit 中的 addLanguageKeysets

import {addLanguageKeysets} from '@gravity-ui/uikit/i18n';
import type {Keysets, PartialKeysets} from '@gravity-ui/date-components';

// 使用 Keyset 类型为所有可用组件指定翻译
addLanguageKeysets<Keysets>(lang, {...});

// 或者使用 PartialKeysets 类型仅指定您需要的翻译
addLanguageKeysets<PartialKeysets>(lang, {...});

// 指定某些组件的翻译
addLanguageKeysets<Pick<Keysets, 'g-date-calendar' | 'g-date-date-field' | 'g-date-date-picker'>>(lang, {...});

开发

要启动带有 storybook 的开发服务器,请运行以下命令:

npm start
关于库
星标
13
版本
3.3.2
最后更新
26.09.2025
代码仓库
github.com/gravity-ui/date-components
许可证
MIT License
维护者
贡献者