Почему состояние обновляется, но я не могу получить к нему доступ через перехватчики в React? - PullRequest
0 голосов
/ 22 октября 2019

У меня проблемы с доступом к моему обновленному глобальному состоянию в реакции через хуки. Я создал пользовательские хуки, чтобы избежать редукторов и всего, что связано с избыточностью, потому что я не фанат этого. Все работает хорошо, но я не могу получить доступ к своему состоянию.

Вот как настроено глобальное состояние

import React, {useState, useMemo, useContext} from 'react'

function makeStore() {
  // Make a context for the store
  const Context = React.createContext();

  // Make a provider that takes an initialValue
  const Provider = ({ initialValue, children }) => {
    // Make a new state instance (could even use immer here!)
    const [state, setState] = useState(initialValue);
    // Memoize the context value to update when the state does
    const contextValue = useMemo(() => [state, setState], [state]);

    // Provide the store to children
    return <Context.Provider value={contextValue}>{children}</Context.Provider>;
  };

  // A hook to help consume the store
  const useStore = () => useContext(Context);

  return { Provider, useStore };
}

const {Provider, useStore} = makeStore();

export {
  Provider,
  useStore
}

Я не забываю обернуть провайдера магазина вокруг компонента приложения

ReactDOM.render(
  <Router basename="">
    <Provider initialValue={initialState} >
      <App />
    </Provider>
  </Router>,
  document.getElementById("root")
);

Компонент App является чистым и в основном используется для маршрутов

const App = () => 
    <div className="App">
      <Route exact path="/" component={props => <Landing {...props} />} />
      <Route exact path="/login" component={props => <Login {...props} />} />
      <Route exact path="/register/:id" component={props => <Register {...props} />}/>
      <PrivateRoute path='/:id' Component={<Content />} />
    </div>



export default App

Когда я попадаю на страницу входа в систему, введите информацию для входа и нажмите кнопку Отправить, состояние обновляется. Единственное, я не могу получить доступ к обновленному состоянию внутри моего компонента.

Вот компонент входа в систему

const Login = ({...props}) => {
    const { register, handleSubmit } = useForm()
    const {auth, setAuth} = useAuth()
    const {loginUser} = AuthApi()
    const onSubmit = data => (async () => {
        const response = await loginUser(data)
        setAuth(response, true)
    })()
    useEffect(() => {
        if(auth.isAuthenticated === true)
            props.history.push('/dashboard')
    }, [])
    return(
        <div className="Auth" style={{backgroundImage: 'url(' + background + ')'}}>
            <div className="Login">
                <div className="Auth-Form Login-Form">
                    <div className="Form-Header">
                        <h4>
                            <b>Login</b>
                        </h4>
                    </div>
                    <div className="Form">
                        <form onSubmit={handleSubmit(onSubmit)}>
                            <input 
                                placeholder="Email"
                                name="email"
                                ref={register({
                                    required: "email required"
                                })}
                            />
                            <br/>
                            <input 
                                placeholder="Password"
                                name="password"
                                ref={
                                    register({
                                        required: "password required"
                                    })
                                }
                            />
                            <br />
                            <input id="submit" type="submit" placeholder="Create Profile"/>
                        </form>
                        <p className="">
                            Don't have an account? <Link to="/register/user">Register</Link>
                        </p>
                        <Link to="/" className="">Back to home</Link>
                    </div>
                </div>
            </div>
        </div>
    )
}

export default Login;

и вот код ловушки useAuth

const useAuth = () => {
    const [{...auth}, setState] = useStore()

    const setAuth = (data, authenticationStatus) => {
        setState(state => {
            state.auth.token = data.token
            state.auth.user = data.user
            state.auth.loading = true
            state.auth.isAuthenticated = authenticationStatus
        })
    }

    return {auth, setAuth}
}

, когда значение auth.isAutheticated покрывает значение true в компоненте входа, ничегослучается. В провайдере состояние обновляется и даже в хуке useAuth я консоль записываю текущее состояние и его обновляемое. Все же я не могу получить к нему доступ в компоненте входа в систему, несмотря на использование useEffects? я что-то упускаю?

1 Ответ

0 голосов
/ 22 октября 2019

этот код происходит только как componentdidmount - один раз:

useEffect(() => {
        if(auth.isAuthenticated === true)
            props.history.push('/dashboard')
    }, [])

изменить на

 useEffect(() => {
            if(auth.isAuthenticated === true)
                props.history.push('/dashboard')
        })
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...