• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

240
Views
REACCIONAR al hacer clic en cambiar el color de div

Estoy tratando de cambiar el color de cada div onClick. El problema en mi código es que todos los divs cambian de color cuando se hace clic en uno. Buscando una manera de cambiar el color de cada uno individualmente

Aquí está mi código:

 class Main extends React.PureComponent { state = { color: 'blue', }; onChange = () => { this.setState({color: 'red'}); }; render() { return ( <Box sx={SX.root}> <Box sx={SX.page}> <Box sx={SX.shapeContainer}> <div style={{backgroundColor: this.state.color, width: 20, height: 20, opacity: '50%'}} onClick={this.onChange} /> <div style={{backgroundColor: this.state.color, width: 20, height: 20, opacity: '50%'}} onClick={this.onChange} /> </Box> <MathGrid sx={SX.math1} /> </Box> <Box sx={SX.header} /> <Box sx={SX.footer} /> </Box> ); }

producción

over 3 years ago · Juan Pablo Isaza
3 answers
Answer question

0

Debe crear un componente separado para cada div con color cambiable. De esta forma, cada componente tendrá su propio estado gestionado de forma independiente. En su ejemplo, comparte el mismo estado de color que el resto.

BoxComponent

 class BoxComponent extends React.Component { state = { color: "blue", }; onChange = () => { this.setState({ color: "red" }); }; render() { return ( <div style={{ backgroundColor: this.state.color, width: 20, height: 20, opacity: "50%" }} onClick={this.onChange} /> ); } }

MainComponent

 class Main extends React.PureComponent { render() { return ( <Box sx={SX.root}> <Box sx={SX.page}> <Box sx={SX.shapeContainer}> <BoxComponent /> <BoxComponent /> </Box> <MathGrid sx={SX.math1} /> </Box> <Box sx={SX.header} /> <Box sx={SX.footer} /> </Box> ); } }
over 3 years ago · Juan Pablo Isaza Report

0

Ambos divs están usando el valor de estado "color". Necesitará usar dos elementos de estado separados para administrar el color de estos dos divs de forma independiente.

También deberá agregar otro controlador onChange o modificar el existente para aceptar un color como argumento.

over 3 years ago · Juan Pablo Isaza Report

0

Está utilizando el mismo estado para ambos cuadros, por lo que cuando cambia su estado, cambiará en todo el componente. Deberá crear estados separados para cada componente. o cree un componente separado para la caja

 <div style={{backgroundColor: this.state.color, width: 20, height: 20, opacity: '50%'}} onClick={this.onChange} /> <div style={{backgroundColor: this.state.color, width: 20, height: 20, opacity: '50%'}} onClick={this.onChange} />
over 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error