在我的React组件中,我有一个按钮意味着点击时通过AJAX发送一些数据。我只需要第一次发生,即在第一次使用后禁用按钮。ReactJs:防止多次按下按钮
如何我试图做到这一点:
var UploadArea = React.createClass({
getInitialState() {
return {
showUploadButton: true
};
},
disableUploadButton(callback) {
this.setState({ showUploadButton: false }, callback);
},
// This was simpler before I started trying everything I could think of
onClickUploadFile() {
if (!this.state.showUploadButton) {
return;
}
this.disableUploadButton(function() {
$.ajax({
[...]
});
});
},
render() {
var uploadButton;
if (this.state.showUploadButton) {
uploadButton = (
<button onClick={this.onClickUploadFile}>Send</button>
);
}
return (
<div>
{uploadButton}
</div>
);
}
});
我认为发生的是状态变量showUploadButton
没有更新向右走,该文档做出反应说,预计。
我该如何强制执行按钮才能禁用或在被点击的瞬间全部离开?
这让我走了一半,但做出反应小组已弃用给裁判一个字符串值,而是与它一起使用回调:https://reactjs.org/docs/refs-and-the-dom.html – Martin