具有动态键名的Reactjs setState()?

JavaScript

逆天L

2020-03-10

编辑:这是重复项,请参阅此处

设置状态时,我找不到使用动态键名的任何示例。这就是我想做的:

inputChangeHandler : function (event) {
    this.setState( { event.target.id  : event.target.value } );
},

其中event.target.id用作要更新的状态键。在React中这不可能吗?

第480篇《具有动态键名的Reactjs setState()?》来自Winter(https://github.com/aiyld/aiyld.github.io)的站点

10个回答
路易小卤蛋 2020.03.10

可以使用传播语法,如下所示:

inputChangeHandler : function (event) {
    this.setState( { 
        ...this.state,
        [event.target.id]: event.target.value
    } );
},
小小Itachi 2020.03.10
this.setState({ [`${event.target.id}`]: event.target.value}, () => {
      console.log("State updated: ", JSON.stringify(this.state[event.target.id]));
    });

请介意引号字符。

伽罗Tom猪猪 2020.03.10

我一直在寻找一个漂亮而简单的解决方案,但发现了这一点:

this.setState({ [`image${i}`]: image })

希望这可以帮助

神乐飞云逆天 2020.03.10

使用ES6 +,您可以执行[ ${variable}]

木心 2020.03.10

我有一个类似的问题。

我想设置第二级密钥存储在变量中的状态。

例如 this.setState({permissions[perm.code]: e.target.checked})

但是,这不是有效的语法。

我使用以下代码实现了这一目标:

this.setState({
  permissions: {
    ...this.state.permissions,
    [perm.code]: e.target.checked
  }
});
Davaid古一 2020.03.10

感谢@Cory的提示,我使用了这个:

inputChangeHandler : function (event) {
    var stateObject = function() {
      returnObj = {};
      returnObj[this.target.id] = this.target.value;
         return returnObj;
    }.bind(event)();

    this.setState( stateObject );    
},

如果使用ES6或Babel编译器来转换JSX代码,您也可以使用计算的属性名称来完成此操作

inputChangeHandler : function (event) {
    this.setState({ [event.target.id]: event.target.value });
    // alternatively using template strings for strings
    // this.setState({ [`key${event.target.id}`]: event.target.value });
}
Green老丝Itachi 2020.03.10

我只是想补充一下,您还可以使用解构来重构代码并使它看起来更整洁。

inputChangeHandler: function ({ target: { id, value }) {
    this.setState({ [id]: value });
},
小小Jim 2020.03.10

与这样的.map工作循环

{
    dataForm.map(({ id, placeholder, type }) => {
        return <Input
            value={this.state.type}
            onChangeText={(text) => this.setState({ [type]: text })}
            placeholder={placeholder}
            key={id} />
    })
}

注意[]in type参数。希望这可以帮助 :)

做个有心人 2020.03.10

我是如何做到的...

inputChangeHandler: function(event) {
  var key = event.target.id
  var val = event.target.value
  var obj  = {}
  obj[key] = val
  this.setState(obj)
},
西门Jim 2020.03.10

当需要处理多个受控输入元素时,可以向每个元素添加一个name属性,并让处理函数根据event.target.name的值选择要执行的操作。

例如:

inputChangeHandler(event) {
  this.setState({ [event.target.name]: event.target.value });
}

问题类别

JavaScript Ckeditor Python Webpack TypeScript Vue.js React.js ExpressJS KoaJS CSS Node.js HTML Django 单元测试 PHP Asp.net jQuery Bootstrap IOS Android