Reactjs setState()具有动态密钥名称?

时间:2015-03-26 14:01:44

标签: javascript reactjs computed-properties

编辑:这是重复的,请参阅here

我在设置状态时找不到使用动态密钥名称的任何示例。这就是我想要做的事情:

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

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

12 个答案:

答案 0 :(得分:232)

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

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

    this.setState( stateObject );    
},

如果使用ES6或Babel transpiler转换JSX代码,您也可以使用computed property names完成此操作:

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 });
}

答案 1 :(得分:99)

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

例如:



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




答案 2 :(得分:38)

我是如何完成这个......

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

答案 3 :(得分:12)

Just wanted to add, that you can also de-structuring to refactor the code and make it look neater.

 SELECT * FROM `users` where Number='1212' OR Number='0921' 

答案 4 :(得分:5)

循环使用.map就像这样:

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

请注意[]参数中的type。 希望这会有所帮助:)

答案 5 :(得分:5)

我有类似的问题。

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

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

但这不是有效的语法。

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

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

答案 6 :(得分:5)

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

请注意引号。

答案 7 :(得分:1)

您的带有字典的状态会更新某些键而不会丢失其他值

 let { parsedFilter } = this.state
 this.setState({
      parsedFilter: {
        ...this.state.parsedFilter,
        page: 5
      }
  });

解决方案低于

{{1}}

此处将键“页面”的值更新为值5

答案 8 :(得分:0)

使用ES6 +,您只需[[${variable}]

答案 9 :(得分:0)

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

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

希望这会有所帮助

答案 10 :(得分:0)

当给定元素是对象时:

handleNewObj = e => {
        const data = e[Object.keys(e)[0]];
        this.setState({
            anykeyofyourstate: {
                ...this.state.anykeyofyourstate,
                [Object.keys(e)[0]]: data
            }
        });
    };

希望它对某人有帮助

答案 11 :(得分:-4)

可以使用扩展语法,如下所示:

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