Реагируйте против CSS-анимации (transform: translateX) - PullRequest
0 голосов
/ 19 октября 2018

Я попытался реализовать в React пример тумблера на W3Schools https://www.w3schools.com/howto/tryit.asp?filename=tryhow_css_switch.

Это мой класс:

class ToggleSwitch {
  constructor(props: any) {
    super(props);

    this.state = { checked: this.props.checked };
    this.toggle = this.toggle.bind(this);
  }

  public render() {
    return (
      <label className="switcher">
        <input type="checkbox" onClick={this.toggle} defaultChecked={this.state.checked} />
      <span className="slider"/>
    </label>,
    document.getElementById("toggleSwitch")
    );
  }
  private toggle() {
    const checked = !this.state.checked;
    this.setState({checked});
    console.log("Checked: " + checked);
  }
}

Иэто мой CSS (такой же, как в примере с W3Schools):

.switcher {
  position: relative;
  display: inline-block;
  width: 112px;
  height: 72px;
  cursor: pointer;
}

.switcher input { 
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #cccccc;
  transition: .4s;
 border-radius: 36px;
}

.slider:before {
  position: absolute;
  content: "";
  height: 60px;
  width: 60px;
  right: 8px;
  left: 8px;
  bottom: 6px;
  background-color: #ffffff;
  transition: .4s;
  border-radius: 50%;
}

.input:checked + .slider {
  background-color: #009ee3;  
}

.input:checked + slider:before {
 transform: translateX(36px);
}

К сожалению, моя кнопка переключения не отображает анимацию, когда вызывается переключатель.Где моя ошибка?

1 Ответ

0 голосов
/ 19 октября 2018

Нашел решение.Я изменил CSS, чтобы иметь два разных класса для переключения и TSX для переключения классов по щелчку.При этом React увидит изменение и перерисовает компонент.

...