• 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

116
Vistas
'Error de tipo: no se pueden leer las propiedades de undefined (leyendo 'push')' cuando se usa el enlace 'useHistory' de 'react-router-dom'

Estoy tratando de usar el enlace "useHistory" de 'react-router-dom' y me encuentro con el error ' TypeError: Cannot read properties of undefined (reading 'push') '. A continuación se muestra mi código.

 import './App.css'; import { React, useState } from 'react' import Header from './Header'; import Register from './Register'; import Login from './Login'; import { BrowserRouter as Router, Switch, Route, useHistory } from 'react-router-dom' function App() { const [ loggedIn, setLoggedIn ] = useState(false) const history = useHistory() return ( <Router> <Header /> <Switch> <Route exact path='/'> {loggedIn ? <h1>Logged In</h1> : <Register setLoggedIn={setLoggedIn} />} </Route> <Route path='/log-in'> {loggedIn ? () => history.push('/') : <Login setLoggedIn={setLoggedIn} loggedIn={loggedIn} />} </Route> </Switch> </Router> ); } export default App;

¿Por qué 'history.push' está causando este error dentro de mi operador ternario?

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

0

import { React, useState } from 'react' import { BrowserRouter as Router, Switch, Route, useHistory } from 'react-router-dom' import Login from './login'; function App() { return ( <Router> <Switch> <Route path='/log-in'> <Login/> </Route> </Switch> </Router> ); } export default App;
 import { useEffect, useState } from "react" import { useHistory } from "react-router-dom" const Login=()=>{ const history=useHistory() const [loggedin,setloggedin]=useState(true) useEffect(()=>{ if(!loggedin){ history.push("/") } },[loggedin]) return( <div>login</div> ) } export default Login

En su código, solo se ejecutará el código dentro de su ruta, es decir

 {loggedIn ? () => history.push('/') : <Login setLoggedIn={setLoggedIn} loggedIn={loggedIn} />}

En el que no se ejecutará el código dentro del componente de su aplicación. Puedes probar el código anterior.

almost 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