react动态增加state_在react中动态更新“state”将覆盖整个状态

好的,所以我尝试在react中构建一个表单,在这里我可以在多个输入中输入值,然后提交并让这些值填充表中指定的单元格。我正在尝试使用“onchange”更新状态,但是当我输入值时,我的初始状态将被完全覆盖。

所以,如果我设定:

state = {

Jan012019: {

first: null,

second: null

}

};

然后尝试通过在“First”的输入中输入“3”来更新状态,方法是:

this.setState(

{

Jan012019: {

[e.target.name]: e.target.value

}

},

function() {

console.log(this.state);

}

);

状态显示为:

Jan012019 {

first: '3'

}

完全从状态中删除“second”,如果我尝试在“second”输入中同时输入值,它将从状态中删除“first”。这是怎么回事?我看到过其他的例子和解决方案,我很确定我的代码和这里的另一个问题的解决方案完全一样,但仍然不能正常工作。完整代码如下。

import React from "react";

class InputForm extends React.Component {

state = {

Jan012019: {

first: null,

second: null

}

};

updateTable = e => {

this.setState(

{

Jan012019: {

[e.target.name]: e.target.value

}

},

function() {

console.log(this.state);

}

);

};

onClick = e => {

e.preventDefault();

console.log(this.state);

};

render() {

return (

First Input

name="first"

type="number"

placeholder="Enter value"

onChange={this.updateTable}

/>

Second Input

name="second"

type="number"

placeholder="Enter value"

onChange={this.updateTable}

/>

Click

);

}

}

export default InputForm;

我还尝试将输入值设置为:

value={this.state.Jan012019.first}

看看这是否有什么不同,但不去。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值