javascript - ReactJS 表单字段的值未更新,并记录为日期字段
问题描述
使用 Reactstrap 进行简单的样式设置,我正在使用他们的<Input>
组件,并且我已经构建了表单,但它不允许文本输入。输入字段时控制台抛出此错误:
我已经设置了组件,并且表单的其余部分工作正常:
constructor(props) {
super(props);
this.state = {
firstName: "",
preferredName: "",
middleName: "",
lastName: "",
address1: "",
address2: "",
city: "",
state: "",
zip: "",
maxContacts: 5,
currentContacts: 0,
releaseDate: Date.now(),
gender: "M",
institutionId: "",
country: "US",
areaCode: 1,
language: "EN",
contacts: []
};
this.onChange = this.onChange.bind(this);
}
onChange = e => {
this.setState({ [e.target.name]: e.target.value });
};
render() {
let prependStyle = {
fontSize: "2pt",
fontFamily: "monospace"
};
在渲染内部,我设置了一些基本样式供以后在组件中使用。这是 JSX 中在组件中表现得很有趣的部分:
<InputGroup>
<InputGroupAddon addonType="prepend" style={prependStyle}>
Institution ID
</InputGroupAddon>
<Input
type="text"
value={this.state.institutionId}
name="instituitonId"
onChange={this.onChange}
/>
</InputGroup>
为什么会这样?(编辑以获取更多信息没有问题。)这是表单中唯一不更新呈现页面上的输入的字段,虽然有一个日期字段,但它被正确地封闭在该元素之外。
解决方案
考虑使用 moment.js 将您的时间转换为组件需要的有效时间格式
所以你releaseDate
会像
formattedReleaseDate = moment(this.state.releaseDate, 'YYYY-MM-DD');
你会想把它放在你的渲染函数中。
推荐阅读
- php - 重定向到来自 PHP 中 API 的 JSON 数组响应中返回的 url
- numpy - 使用 cython 加速数组合并计算
- rxjs - RxJS过滤和选择/取消选择复选框列表
- c++ - 如何在 Poco 中将工作 HTTP 代码转换为 HTTPS
- php - 如何让我的静态网站在 wamp 中公开
- javascript - 如何使用关键细节修改嵌套对象的属性
- python - 如何在python中完成id号生成器代码
- android - 如何在自定义对话框类中使用 getActivity.getLayoutInflater()
- ios - 创建一个 Facebook 登录按钮,如 Apple Signin
- python - 使用 Matplotlib Python 创建箱线图