即使我不调用setstate React

时间:2019-10-01 09:54:31

标签: javascript reactjs

(反应16.8.6) 我有一个问题,当变量更改时,即使我不调用任何setState,它也会自动更改状态。在分配值时,在handleInputChange中,它会自动更新状态clientsData和editedClientsData。我只想更新editedClientsData。

代码如下:

1-设置状态(单击按钮时触发):

getClients(calls) {
axios.all(calls)
    .then(responseArr => {
        let cleanedDate = []
        responseArr.map(el => {
            cleanedDate.push(el.data.data)
        })
        this.setState({
            clientsData: cleanedDate,
            editedClientsData: cleanedDate,
            loading: false
        })
        this.loadDataChart()
    });
}

2-加载输入字段

render(){
    return (...
        this.state.editedClientsData.map(this.renderInput)
    ...)
}

renderInput = (client, i) => {
    const { activeYear } = this.state
    return (<tr key={client.id}>
        <td>{client.name}</td>
        <td><Input
            type="number"
            name={client.id}
            id="exampleNumber"
            placeholder="number placeholder"
            value={client.chartData[activeYear].r}
            onChange={this.handleInputChange}
        /></td>
        <td>{client.chartData[activeYear].x}</td>
        <td>{client.chartData[activeYear].y}</td>
    </tr>
    )
}

handleInputChange(event) {
    let inputs = this.state.editedClientsData.slice();
    const { activeYear } = this.state
    for (let i in inputs) {
        if (inputs[i].id == event.target.name) {
            inputs[i].chartData[activeYear]['r'] = parseFloat(event.target.value)
            console.log(inputs)
            // this.setState({ editedClientsData: inputs })
            break;
        }
    }
}

我试图分配一个固定号码 我试图另存为const {clientsData} = this.state,更新了editedClientsData和this.setState({clientsData})

所有这些测试均失败。希望有您的帮助,谢谢!

1 个答案:

答案 0 :(得分:0)

getClients函数中,您正在为状态的两个道具(cleanedDateclientsData)分配相同的数组editedClientsData

这两个属性均指向。因此,编辑将同时反映到这两个属性。现在,假设该数组包含对象,那么使用slice复制该数组也将不起作用,因为两个不同的数组都包含对同一数据的引用。考虑下面的示例:

var a = [{prop: 1}];
var b = a.slice();
var c = a.slice();
console.log(c == b); // false
b[0].prop = 2;
console.log(b[0].prop); // 2
console.log(c[0].prop); // also 2, because slice does shallow copy.

在这种情况下,您需要深度复制数据,因此不会重复引用。您可以为此使用Lodash实用程序,也可以为此创建自己的实用程序。