0

单击我的 react-bootstrap ToggleButtons 时遇到问题。他们似乎两次触发了 handlePlatformChange() 函数——它首先传递了正确的 id,然后在传递 null 之后立即传递。我遇到的一个选项是在函数中包含 e.preventDefault() ,但这会阻止按钮正确切换。我已经用尽了我能想到的所有选择——任何建议都将不胜感激。

import React, {Component} from 'react';
import 'bootstrap/dist/css/bootstrap.min.css';
import './App.css';
import Button from 'react-bootstrap/Button';
import ToggleButton from 'react-bootstrap/ToggleButton';
import ToggleButtonGroup from 'react-bootstrap/ToggleButtonGroup';

class App extends Component {
  constructor () {
    super();
    this.state = {
        User : "",
        Platform: "battle",
        Player: "",
        Level: ""
    };

    this.handleChange = this.handleChange.bind(this);
  }

  handlePlatformChange = (e) => {
    this.setState({Platform: e.target.id}, function () {
      console.log(this.state.Platform);
    });
  }
    
    
  handleChange(e) {
    if (e.target.id === "usernameinput") {
      this.setState({User: e.target.value});
    }
  }

    render() {
        return (
          <div className="infoSection">
          <div className="center">
            <input type="text" id="usernameinput" value={this.state.value} onChange={this.handleChange} placeholder="Username" /><br/>
            <ToggleButtonGroup id="buttongroup" name="buttongroup" defaultValue={[1]}>
              <ToggleButton id="battle" value={1} variant="secondary" onClick={this.handlePlatformChange}></ToggleButton>
              <ToggleButton id="acti" value={2} variant="secondary" onClick={this.handlePlatformChange}></ToggleButton>
              <ToggleButton id="psn" value={3} variant="secondary" onClick={this.handlePlatformChange}></ToggleButton>
              <ToggleButton id="xbl" value={4} variant="secondary" onClick={this.handlePlatformChange}></ToggleButton>
            </ToggleButtonGroup>
            <br/>
              <Button id="searchButton" variant="primary">Search</Button>
              <div className="displaySection">

                <p id="displayHeader">Username: {this.state.Player}<br/>
                Level: {this.state.Level}</p>
                <p id="displayInfo1">some info here</p>
                <p id="displayInfo1">some info here</p>
              </div>
          </div>
          </div>
        );
}
}

export default App;
4

1 回答 1

0

您的ToggleButton元素实际上是标签内的输入。将此元素转换为您拥有的纯 html(第一个按钮的示例):

<label id="battle" variant="secondary" type="button" class="btn btn-default active"
  <input type="radio" name="buttongroup" autocomplete="off" value="1"></input>
</label>

您想要的 id 在标签标签上,但是当您单击输入时,您只会到达输入标签。

因此,要解决您的问题,您需要将 handlePlatformChange 方法更改为:

handlePlatformChange = (e) => {
    this.setState({Platform: e.target.parentNode.id}, function () {
      console.log(this.state.Platform);
    });
  }
于 2020-12-30T12:46:29.990 回答