javascript - 自定义rc-time-picker的样式

标签 javascript css reactjs frontend timepicker

我正在为我的元素使用 rc-time-picker 包,但我在自定义 time picker< 的 pop-up 样式时遇到问题 组件。这是我的组件的屏幕截图:

screenshot of component

首先,我需要将时间 li 中时间 item 的背景颜色从 light grey(在屏幕截图中)更改为#edeffe 当时间悬停并被选中时。以下是我的代码:

import React from "react";
import TimePicker from "rc-time-picker";
import "rc-time-picker/assets/index.css";
import styled from 'styled-components';

const StyledTimePicker = styled(TimePicker)`
 &.rc-time-picker-panel-select-option-selected{
    background-color: #edeffe !important;
  }
`;

const DeliTimePicker = ({ value, onChange, ...others }) => {
  return (
    <StyledTimePicker
      showSecond={false}
      onChange={onChange}
      hideDisabledOptions
      minuteStep={5}
      {...others}
      value={value}
      use12Hours
    />
  );
};

export default DeliTimePicker;

在浏览器中查看,我发现每一项被选中时的className都是rc-time-picker-panel-select-option-selected。我还必须在我的元素中使用 styled component 包来设置样式。我不明白为什么它不能通过这种方法工作。最终组件应如下所示:

final rendering

这是codesandbox链接:https://codesandbox.io/s/kk8lllwwp7?fontsize=14

任何答案将不胜感激!

最佳答案

您需要重新安排您对 TimePicker 组件进行样式化的顺序。 styled-components 包生成一个className,需要应用到TimePicker。在这种情况下,它将应用于它的 className 和它的 popupClassName

工作示例:

Edit Styled Time Picker

组件/TimePicker/index.js

import styled from "styled-components";
import TimePicker from "./TimePicker";

const StyledTimePicker = styled(TimePicker)`
  & .rc-time-picker-panel-select-option-selected {
    background-color: #edeffe;
    font-weight: normal;
  }

  & .rc-time-picker-clear,
  & .rc-time-picker-clear-icon:after {
    font-size: 15px;
  }

  & .rc-time-picker-panel-select,
  & .rc-time-picker-input,
  & .rc-time-picker-panel-input {
    font-family: "Consolas", sans-serif;
    font-size: 16px;

    ::-webkit-scrollbar {
      width: 0;
      height: 0;
    }
  }
`;

export default StyledTimePicker;

组件/TimePicker/TimePicker.js

import React from "react";
import PropTypes from "prop-types";
import moment from "moment";
import TimePicker from "rc-time-picker";
import "rc-time-picker/assets/index.css";

const DeliTimePicker = ({ className, onChange, value, ...rest }) => (
  <TimePicker
    {...rest}
    className={className}
    popupClassName={className}
    showSecond={false}
    onChange={onChange}
    hideDisabledOptions
    minuteStep={5}
    value={value}
    use12Hours
  />
);

DeliTimePicker.propTypes = {
  className: PropTypes.string.isRequired,
  onChange: PropTypes.func.isRequired,
  value: PropTypes.instanceOf(moment)
};

export default DeliTimePicker;

组件/TimeSelectForm/index.js

import React, { Component } from "react";
import moment from "moment";
import TimePicker from "../TimePicker";

class TimeSelectForm extends Component {
  state = {
    value: moment()
  };

  handleChange = value => this.setState({ value });

  handleSubmit = e => {
    e.preventDefault();
    alert(moment(this.state.value).format("hh:mm a"));
  };

  render = () => (
    <form onSubmit={this.handleSubmit}>
      <TimePicker value={this.state.value} onChange={this.handleChange} />
      <br />
      <button type="submit">Submit</button>
    </form>
  );
}

export default TimeSelectForm;

关于javascript - 自定义rc-time-picker的样式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55189678/

相关文章:

reactjs - 如何让我的 React 应用程序使用 CRUD 渲染 Bootstrap 表

javascript - 使 iFrame 不在页面启动时加载

javascript - 如何计算 2 个 Javascript 对象之间的匹配百分比?

javascript - 在 JS 中移动元素

html - 在不同浏览器中使用 WordPress 字体

html - 调整窗口大小时 float 框

javascript - 有没有办法以我的示例通过 React Native Expo 来执行后台任务?

javascript - 显示延迟的网络摄像头/摄像头流 - webrtc

javascript - 如何在 JavaScript 中将变量用作字符串?

javascript - React checkedLink 如何访问更改值