Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html>
<head>
<script src="//fb.me/react-0.13.1.js"></script>
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
<body>
  <div id="app"></div>
</body>
</html>
 
class IndeterminateCheckbox extends React.Component {
  componentDidMount() {
    if (this.props.indeterminate === true) {
      this._setIndeterminate(true);
    }
  }
  componentDidUpdate(previousProps) {
    this._setIndeterminate(this.props.indeterminate);
  }
  _setIndeterminate(indeterminate) {
    const node = React.findDOMNode(this);
    node.indeterminate = indeterminate;
  }
  render() {
    const { indeterminate, type, ...props } = this.props;
    return <input type="checkbox" {...props} />;
  }
}
class App extends React.Component {
  constructor() {
    super();
    this.toggleChecked = this.toggleChecked.bind(this);
    this.toggleIndeterminate = this.toggleIndeterminate.bind(this);
    this.state = {
      checked: false,
      indeterminate: false
    }
  }
  render() {
    return (
      <div>
        <div>
          <IndeterminateCheckbox
            checked={this.state.checked}
            indeterminate={this.state.indeterminate} />
        </div>
        <div>
          <button onClick={this.toggleChecked}>
            Checked: {String(this.state.checked)}
          </button>
          <button onClick={this.toggleIndeterminate}>
            Indeterminate: {String(this.state.indeterminate)}
          </button>
        </div>
      </div>
    );
  }
  toggleChecked() {
    this.setState(s => ({checked: !s.checked}));
  }
  toggleIndeterminate() {
    this.setState(s => ({indeterminate: !s.indeterminate}));
  }
}
React.render(<App />, document.getElementById("app"));
Output

You can jump to the latest bin by adding /latest to your URL

Dismiss x
public
Bin info
BinaryMusepro
0viewers