• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

W React, nie działa this.setState dlaczego?

VPS Starter Arubacloud
0 głosów
124 wizyt
pytanie zadane 6 stycznia 2020 w JavaScript przez Mariusz Podgórski Początkujący (400 p.)

Witam, jak w tytule.

Buduję prosty CMS i chce się zalogować jeżeli sprawdzę warunek, że jest prawdziwy wszystko działa. jednak chce wyczyścić pola wpisywania jeżeli warunek jest niepoprawny i to już się nie dzieje dlaczego? dodam tylko, że program wchodzi do else sprawdzałem za pomocą console.log(); czy ktoś mógłby mi to wytłumaczyć dlaczego nie działa?.

chodzi dokładnie o funkcję   handleSubmit

import React from 'react'
import { Route, Redirect } from 'react-router-dom'
import axios from 'axios'


const password = '123'
const login = 'maniek'


class Login extends React.Component {



    state = {
        loginSt: '',
        passwordSt: '',
        loginPermission: false,
    }

    handleChange = (e) => {


        if (e.target.type === 'text') {
            this.setState({
                loginSt: e.target.value,
            })
        } else if (e.target.type === 'password') {
            this.setState({
                passwordSt: e.target.value,
            })
        }

    }

    handleSubmit = (e) => {
        e.preventDefault();

        axios.get(`http://localhost:4000/login`)
            .then(res => console.log(res.data))
            .catch(err => console.log(err))




        if (password === this.state.passwordSt && login === this.state.loginSt) {

            const loginPermission = true;

            this.props.handlelLoggedStatus(loginPermission);

            this.setState({

                loginPermission,

            })



        } else {
            const login = '';
            const password = '';

            this.setState({
                login,
                password,
            })

        }

    }


    render() {


        if (this.state.loginPermission) {

            return (

                <Route render={() => (
                    (
                        <Redirect to='/admin' />
                    )
                )} />

            )

        } else {
            return (

                < div className='login-page' >
                    <form className='login-page__login-container' onSubmit={this.handleSubmit}>
                        <input className='login-page__login' type='text' placeholder='Login' onChange={this.handleChange} value={this.state.loginSt}></input>
                        <input className='login-page__password' type='password' placeholder='hasło' onChange={this.handleChange} value={this.state.passwordSt}></input>
                        <button className='login-page__submit-button'>zatwierdź</button>
                    </form>
                </div>

            )
        }

    }
}
export default Login;

 

1 odpowiedź

+1 głos
odpowiedź 6 stycznia 2020 przez Qwizi Obywatel (1,280 p.)
this.setState({
 loginSt: login, 
 passwordSt: password
})

Tak powinienies ustawiac state.

komentarz 7 stycznia 2020 przez Mariusz Podgórski Początkujący (400 p.)
Dzięki bardzo co za jełop ze mnie siedzę ryje 4 godzinę i już mi się łeb lasuję i nie zauważam najprostszych błędów.

Dzięki jeszcze raz.

Podobne pytania

0 głosów
1 odpowiedź 71 wizyt
pytanie zadane 29 września 2020 w JavaScript przez User007 Bywalec (2,400 p.)
0 głosów
0 odpowiedzi 63 wizyt
pytanie zadane 15 października 2020 w JavaScript przez poldeeek Mądrala (5,980 p.)
0 głosów
1 odpowiedź 312 wizyt
pytanie zadane 30 maja 2022 w JavaScript przez Zaqu93 Gaduła (4,850 p.)

92,453 zapytań

141,262 odpowiedzi

319,088 komentarzy

61,854 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...