Состояние Redux не меняется в зависимости от ввода - PullRequest
0 голосов
/ 28 ноября 2018

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

В constants.js

export const USER_LOGGED_IN = 'USER_LOGGED_IN';

В actions.js

import * as constants from './constants';

export const userLoggedIn = (text) => ({
  type: constants.USER_LOGGED_IN,
  payload: text
});

В reducer.js

import * as actionName from "./constants";

const initialStateLoggedIn = {
  email: "",
};

export const userLoggedInReducer = ( state = initialStateLoggedIn, action = {} ) => {
  switch (action.type) {
    case actionName.USER_LOGGED_IN:
      return {
        ...state,
        email: action.payload,
      };
    default:
      return state;
  }
};

В index.js

import { createStore, combineReducers, applyMiddleware } from "redux";
import { Provider } from "react-redux";
import thunkMiddleware from "redux-thunk";
import { createLogger } from "redux-logger";
import { userLoggedInReducer } from "./reducers";
import { composeWithDevTools } from "redux-devtools-extension";

const logger = createLogger();

const rootReducers = combineReducers({ userLoggedInReducer });

const store = createStore(
  rootReducers,
  composeWithDevTools(applyMiddleware(thunkMiddleware, logger))
);

ReactDOM.render(
  <Provider store={store}>
    <App />
  </Provider>,
  document.getElementById("root")
);

В SignIn.js

import { connect } from "react-redux";
import { userLoggedIn } from "./../../actions";

const mapStateToProps = state => {
  console.log(`mapStateToProps: ${state.userLoggedInReducer.email}`); //I think this is where it reads the input real time?
  return { email: state.userLoggedInReducer.email };
};

const mapDispatchToProps = dispatch => {
  return {
    onEmailFilled: event =>
      dispatch(userLoggedIn(event.target.signin_email.value))
  };
};

  render() {
    const { email, onEmailFilled } = this.props;
    console.log(`Hello ${email}`);
    return{
      <form ......
         <InputComponent
            id_name="signin_email" //this is the name attribute
            input_label="Email"
            input_type="email"
            function="{onEmailFilled}" //can I pass onEmailFilled like this?
        />
    .......
    export default connect( mapStateToProps, mapDispatchToProps)(SignIn);
}

В InputComponent.js

import React, { Component } from "react";

class InputComponent extends Component {
  render() {
    return (
      <div className="measure mt4 mt4-1 mt4-m mt4-ns">
        <label htmlFor={this.props.id_name} className="f6 b db mb2">
          {this.props.input_label}
          {this.props.isOptional ? (
            <span className="normal black-60">(optional)</span>
          ) : null}
        </label>
        <input
          id={this.props.id_name}
          name={this.props.id_name}
          className="input-reset ba b--black-20 pa2 mb2 db w-100 lh-copy lh-copy-l lh-copy-m lh-copy-ns"
          type={this.props.input_type}
          autoComplete="on"
          onChange={this.props.function} //passed from SignIn.js
        />

      </div>
    );
  }
}

export default InputComponent;

У меня есть расширение Chrome, и я знаю, что вместо этого я должен искать отладкуиспользования console.log, но я со временем научусь, как только буду прогрессировать.В mapStateToProps и в render () console.log они ничего не возвращали, когда я набирал элемент input.

Что я пропустил, потому что это приложение не меняет состояние?Некоторое объяснение будет хорошим, так что я могу понять, как реагировать на избыточность.Спасибо.

1 Ответ

0 голосов
/ 28 ноября 2018

В SignIn.js

  render() {
    const { email, onEmailFilled } = this.props;
    console.log(`Hello ${email}`);
    return{
      <form ......
         <InputComponent
            id_name="signin_email" //this is the name attribute
            input_label="Email"
            input_type="email"
            emailFilled={onEmailFilled} 
        />
    .......

В InputComponent.js

<input
  id={this.props.id_name}
  name={this.props.id_name}
  className="input-reset ba b--black-20 pa2 mb2 db w-100 lh-copy lh-copy-l lh-copy-m lh-copy-ns"
  type={this.props.input_type}
  autoComplete="on"
  onChange={this.props.emailFilled}

Мне удалось решить эту проблему, внеся некоторые незначительные изменения.Расширение Redux также показывает обновления.Решаемые.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...