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

0

175
Views
¿Cómo puedo configurar el estado para permitir que un componente secundario represente otro?

Tengo un componente principal que tiene dos componentes secundarios y seis de cada uno.

Algo como esto:

 <Main> <Component1 /> <Component1 /> <Component1 /> <Component1 /> <Component1 /> <Component1 /> <Component2 /> <Component2 /> <Component2 /> <Component2 /> <Component2 /> <Component2 /> </Main>

Mi objetivo es poder renderizar un Component2 específico basado en un cambio del Componente 1.

Entonces, hacer clic en el primer Componente1 alternaría el renderizado del primer Componente2

He intentado algo como esto en mi componente principal:

 const [component2Visible, setcomponent2Visible] = useState([false, true, false, false, false, false])

Pero no creo que esta sea la dirección correcta en absoluto.

almost 3 years ago · Juan Pablo Isaza
1 answers
Answer question

0

Aquí hay un enfoque que podría emplear:

 // state variables to hold arguments to generate Component1 & Component2 // Component1 args have a prop named 'hideC2' (initially set to false) const [comp1Args, setComp1Args] = useState([{hideC2: false, ...}, {hideC2: false, ....}, {}]); const [comp2Args, setComp2Args] = useState([{}, {}, {}]); . . . // Iterate over the two args arrays to generate Components // Use '.filter' on comp2Args to 'hide' those where 'hideC2' is set to true return ( <Main> { comp1Args.map((args, idx) => ( <Component1 key={idx} args={args} onToggleC2={() => setComp1Args(prev => { const curr = [...prev]; curr[idx].hideC2 = !prev[idx].hideC2; return [...curr] })} /> )) } { comp2Args .filter((el, idx) => (comp1Args[idx].hideC2 !== true)) .map((args, idx) => ( <Component2 key={idx} args={args}/> )) } </Main> );
almost 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