javascript - 无法更新状态内的嵌套对象

标签 javascript reactjs object state spread-syntax

import React, { Component } from 'react';
import ColorBox from './ColorBox'
import './ColorBoxes.css'

class ColorBoxes extends Component {
    state = { 
        colors: {}
    }

    clickedColor = (color) => {
        let newColor = this.randomColorGenerator()
        if (color !== newColor) {
            console.log('i am changing state', newColor)
            console.log(color, 'i am current color')
            console.log(this.state.colors)

            const {colors} = this.state
            this.setState({
                colors: {
                    ...colors,
                    [color]: newColor
                }
            })
        }

    }

    randomColorGenerator = () => {
        let randomColor = '#'+Math.floor(Math.random()*16777215).toString(16)
        return randomColor
    }

    renderColors = () => {
        let colors = []
        colors = Object.keys(this.state.colors)
        return colors.map(c => 
        <div key={c}><ColorBox color={c} clickedColor={this.clickedColor}/></div>)
    }

    componentDidMount() {
        let colorKey
        let colors = {}
        for(let i=0; i < 21; i++) {
            colorKey = this.randomColorGenerator()
            colors[colorKey] = colorKey

        }
        this.setState({ colors: colors  });
    }
    render() { 

        return ( 
            <div className="ColorBoxes">
                {this.renderColors()}
            </div>
        );
    }
}
export default ColorBoxes;

子组件

import React from 'react';
import './ColorBox.css'

const ColorBox = (props) => {
    return <div className='ColorBox' 
    style={{backgroundColor: `${props.color}`}}
    onClick={() => props.clickedColor(props.color)}>
        {props.color}
    </div>
}

export default ColorBox;

编辑,我已经尝试了建议的解决方案,但是状态已更新,基于 react 开发人员工具,但组件没有重新渲染。我怀疑 key 也必须更改才能重新渲染,但我不知道如何在状态下执行此操作 我想做的是将旧 key 替换为正在更新的相同颜色。

我有这个颜色对象的状态,它保存颜色的键:值对,例如颜色:{#fff: #fff, #bbb: #bbb}。我将一个函数向下传递给子组件,这样当我单击一种颜色时,它将返回该颜色,这是我在状态对象中的键,然后我想找到该键并将该键值更新为新的随机颜色将被选择。我无法访问该 key 。我怎么做?理想情况下,我可能希望删除该键并将键和值更新为状态对象中的相同值。

最佳答案

假设您的状态如下所示:

colors: {
  #fff: '#fff',
  #000: '#000'
}

然后只需将您的 setState 更新为

const {colors} = this.state
setState({
  colors: {
    ...colors,
    [color]: newColor
  }
})

问题是您在颜色对象之外附加了新的颜色状态

关于javascript - 无法更新状态内的嵌套对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60089219/

相关文章:

javascript - onclick 没有在 react 中触发

reactjs - 为什么 "import { React } from ' react ';“不起作用?

javascript - 解构复杂对象

C++ Visual Studio 2017 使用我的对象 vector 获取错误代码 C3867

javascript - 如果我将 mouseLeave() 转移到另一个特定的 div,如何防止带有 sliderDown() 的 div 和带有 mouseLeave() 触发器的 SlideUp() 触发?

javascript - 在 Jquery 中通过单击/单击删除单击的类?

javascript - Iframe 内容窗口

reactjs - 使用 BrowserRouter Lazy 和 Suspense 延迟加载页面

javascript - 获取嵌套对象/数组 JavaScript 的值

javascript - 如何确保搜索引擎可以看到我的 "single page"Backbone.js 网站上的内容?