• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

122
Vistas
Invocar métodos secundarios con componentes de función y ganchos en React

Estoy tratando de cambiar de usar componentes de clase a componentes de función y ganchos en ReactJS. He creado un programa simple para ilustrar lo que estoy tratando de hacer.

Este es un componente secundario, que tiene un nombre y un valor:

 function Child(props) { const [value, setValue] = useState(0) function increment() { setValue(value + 1) } return (<div>Child ({props.name}): {value}</div>) }

El componente secundario se pasaría a un elemento principal, que tiene su propio valor, y cuando este valor disminuye, el valor del elemento secundario debe incrementarse:

 function Parent(props) { const [value, setValue] = useState(10) function decrement() { setValue(value - 1) } return (<div> <div>Parent: {value}</div> <button onClick={decrement}>Pass from parent to child</button> {props.child} </div>) }

El niño pasa al padre el nivel de la aplicación (en teoría, los niños se pueden cambiar dinámicamente, pero para simplificar aquí establecemos uno de dos):

 function Application(props) { const child1 = <Child name="Alice" /> const child2 = <Child name="Bob" /> const child = props.option == "Alice" ? child1 : child2 return (<Parent child={child} />) }

Ahora lo que necesito aquí es que cuando el valor del padre disminuye, el valor del hijo debe incrementarse. En React, no llamas directamente al método de un componente secundario desde el padre, por lo que estoy buscando una manera de lograr esto que también me permita cambiar el componente secundario como se muestra en el código.

Si ejecuta el lápiz de código a continuación, esto tendrá sentido.

códec

about 3 years ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

Aquí está la solución que busca

 const { useState } = React; function Parent(props) { const [value, setValue] = useState(10) const [childValue, setChildValue] = useState(0) function changeValue(){ setValue(value-1); setChildValue(childValue + 1); } return (<div> <div>Parent: {value}</div> <button onClick={changeValue}>Pass from parent to child</button> <Child name={props.option} value={childValue} /> </div>) } function Child(props) { return (<div>Child ({props.name}): {props.value}</div>) } function Application(props) { // Child component is decided by the Application component and can change at any time return (<Parent option={props.option} />) }

En lugar de pasar el componente secundario del componente de la aplicación, pase del componente principal.

Espero que esto sea lo que estás buscando.

about 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda