React formcontrol onChange未被触发
我试图在React中获得一个简单的形式,但我似乎无法正常工作。我还为我的GUI组件使用react-bootstrap
。 我有一个称为库存
的组件,该组件保存表单:
class Inventory extends React.Component {
constructor(props) {
super(props);
this.handleChange = this.handleChange.bind(this);
this.handleSubmit = this.handleSubmit.bind(this);
this.state = {
'upc' : ''
}
}
handleChange(event) { this.setState({'upc' : event.target.value }); }
handleSubmit(event) {
// Do some stuff
}
render() {
return (
<Container fluid>
<h1>Inventory Page</h1>
<Row>
<Col>
<Form onSubmit={this.handleSubmit}>
<Form.Group className="mb3" controlId="invUpcForm">
<Form.Label>UPC</Form.Label>
<Form.Control type="text" placeholder="123456789012" />
<Form.Text value={this.state.upc} onChange={this.handleChange} className="text-muted">
Ensure the field is focused, and scan the barcode.
</Form.Text>
</Form.Group>
<Button variant="primary" type="submit">Submit</Button>
</Form>
</Col>
</Row>
</Container>
);
}
}
但是,尽管我在字段的值更改时,每当我在输入字段中输入任何文本时,handlechange
都永远不会被调用。如果我提交字段,请在状态中检查upc
的值,显示其为空''
。
我在做什么错?
I am trying to get a simple form working in React but I can't seem to get it working. I am also using react-bootstrap
for my GUI components.
I have a component called Inventory
that holds the form:
class Inventory extends React.Component {
constructor(props) {
super(props);
this.handleChange = this.handleChange.bind(this);
this.handleSubmit = this.handleSubmit.bind(this);
this.state = {
'upc' : ''
}
}
handleChange(event) { this.setState({'upc' : event.target.value }); }
handleSubmit(event) {
// Do some stuff
}
render() {
return (
<Container fluid>
<h1>Inventory Page</h1>
<Row>
<Col>
<Form onSubmit={this.handleSubmit}>
<Form.Group className="mb3" controlId="invUpcForm">
<Form.Label>UPC</Form.Label>
<Form.Control type="text" placeholder="123456789012" />
<Form.Text value={this.state.upc} onChange={this.handleChange} className="text-muted">
Ensure the field is focused, and scan the barcode.
</Form.Text>
</Form.Group>
<Button variant="primary" type="submit">Submit</Button>
</Form>
</Col>
</Row>
</Container>
);
}
}
However, whenever I enter any text into the Input field, handleChange
never gets called despite the value of the field changing. If I submit the field, checking the value of upc
in state shows it is empty ''
.
What am I doing wrong?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
你必须这样改变。
这是因为form.control是一个真实的输入组件,并且form.text组件只是简单的div/跨度渲染文本。您可以通过检查Chrome浏览器中的元素来检查它。
You gotta change like this.
It is because Form.Control is a real input component, and Form.Text component is just a simple div/span to render text. You can check it by inspecting element in chrome browser.
根据此示例来自 react-bootstrap docs ,您应该附加您的
value> value
和和<代码> onChange props of&lt; form.control/&gt;
组件,而不是&lt; form.text/&gt;
。表单文本是用于帮助文本的,而表单控制处理实际输入元素。According to this example from the react-bootstrap docs, you should be attaching your
value
andonChange
props to the<Form.Control />
component, not<Form.Text />
. Form text is for help text, while the form controls handle the actual input elements.