UseForm en Reaccionar es "un clic detrás de" [duplicar]

0

Pregunta

Estoy usando useForm gancho en reaccionar, y por alguna razón cuando introduzca los valores en el formulario y haga clic en el botón de enviar, el estado no toma los valores que he presentado, pero toma los valores de vacío.

Entonces, cuando entro en un segundo conjunto de valores en el formulario y enviarlo, el estado toma los valores de la primera presentación.

Parece que siempre va "a un clic de atrás" (ver la consola.registro en el registerAccount función)

He enlazado el handleSubmit dentro de la con el registerAccount función, que debe ejecutar la actualización del estado que mantiene las cuentas en el primer clic.

Me estoy perdiendo algo?

import {useForm} from 'react-hook-form'

const AddAccount = ()=> {

    const {register, handleSubmit, formState: { errors }} = useForm()
    
    const [items, setItems] = useState([])

    const registerAccount = (data)=> {
          setItems([...items, data]) 
          console.log(items)
    }

return(

<div>    

    <div className="grid grid-cols-1 justify-items-center">
        <h1 className="text-black font-bold py-2 text-2xl" >Agrega una cuenta</h1>
        <form onSubmit={handleSubmit(registerAccount)}>
            <table className="table-fixed">
                <thead>
                    <th className="w-1/2 "></th>
                    <th className="w-1/2 "></th>
                </thead>
                <tbody>
                    <tr>
                        <td><label className="py-1">Alias de la cuenta: </label></td>
                        <td><input defaultValue="" name="accountAlias" placeholder="Alias" 
                        className= "my-3 border-solid border-2 border-gray-900 py-1 px-3" 
                        {...register("accountAlias", {required: "Introduce el nombre de la cuenta"})}/>
                        <p className="text-red-500 text-sm">{errors.accountAlias?.message}</p>
                            </td>
                            
                    </tr>
                    <tr>
                        <td><label className="py-1">Tipo de cuenta: </label></td>
                        
                        <td><select name="accountType" className= "my-3 border-solid border-2 border-gray-900 py-1 px-3"
                        {...register("accountType", {required: "Selecciona el tipo de cuenta"})}>
                            <option value="">Selecciona...</option>
                            <option value="cuenta de gastos">Cuenta de gastos</option>
                            <option value="ahorro">Ahorro</option>
                            <option value="tarjeta de crédito">Tarjeta de crédito</option>
                            <option value="inversión">Inversión</option>
                            </select>
                            <p className="text-red-500 text-sm">{errors.accountType?.message}</p>
                            </td>
                    </tr>
                    <tr>
                        
                    </tr>
                </tbody>
            </table>

            <button className="bg-blue-500 text-white py-2 px-6 px-2 mt-4">Agregar</button>
        </form>
    </div>

</div>
)
}

export default AddAccount```
1

Mejor respuesta

0

el problema está en tu consola.log(). está escrito de registro de la consola antes de que el estado es que se está actualizando. desde useState está realizando de forma asincrónica.

si quieres ver tus artículos de estado, entonces usted necesita para utilizar useEffect de la siguiente manera.

   useEffect(() => {
        console.log(items)
    }, [items]);
2021-11-24 05:29:23

genial, muchas gracias!
Robtc83

En otros idiomas

Esta página está en otros idiomas

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Slovenský
..................................................................................................................