单击我的 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;