Магазин Redux не подключен - PullRequest
       28

Магазин Redux не подключен

0 голосов
/ 20 февраля 2019

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

rout.js

const RouteList = () => (
  <main>
    <Switch>
      <Route path="/abc/" exact component={withRouter(HomePage)} />
      <Route path="/abc/xyz" exact component={withRouter(XYZPage)} />
      <Redirect from="/" to="/abc/" />
      <Route component={Error} />
     </Switch>
   </main>
);
export default RouteList;

App.js

class  App extends React.Component {
  constructor(props) {
    super(props);
    this.state = {};
  }

  render () {
    return (
      <Router history={browserHistory}>
        <div>
          <Header />
          <RouteList />
          <Footer />
        </div>
      </Router>
    );
  }
}

export default App;

Header.js

const Header = () => {
  return (
    <Navbar expand="md">
      <NavbarBrand tag={NavLink} to="/">
        <img src={brandImage} style={{marginRight: "0", width: "40px", height: "40px"}} /><strong style={{color: "#457B9D"}} >Datum</strong>
      </NavbarBrand>

      <Nav className="mr-auto" navbar>
        <NavItem>
          <NavLink className="nav-link" to={"/abc/xyz"} >XYZ</NavLink>
        </NavItem>
      </Nav>
    </Navbar>
  );
};

export default withRouter(Header);

Когда я нажимаю на ссылку NavLink, которая приведет меня к URL: / "abc / xyz", он приведет меня к XYZPage.js

XYZPage.js

class XYZPage extends React.Component {
  constructor(props, context) {
    super(props, context);

    this.state = {
      activeTab: "1"
    };

    this.toggle = this.toggle.bind(this);
  }

  toggle(tab) {
    if (this.state.activeTab !== tab) {
      this.setState({
        activeTab: tab
      });
    }
  }
  render () {
    return (
      <main>
        <div className="container-fluid pt-3">
          <Nav tabs>
            <NavItem>
              <NavLink
                className={classnames({active: this.state.activeTab === "1"})}
                onClick={() => {this.toggle("1"); }} >
                AAA
              </NavLink>
            </NavItem>
            <NavItem>
              <NavLink
                className={classnames({active: this.state.activeTab === "2"})}
                onClick={() => {this.toggle("2"); }} >
                BBB
              </NavLink>
            </NavItem>
            <NavItem>
              <NavLink
                className={classnames({active: this.state.activeTab === "3"})}
                onClick={() => {this.toggle("3"); }} >
                CCC
              </NavLink>
            </NavItem>
          </Nav>
          <TabContent activeTab={this.state.activeTab}>
            <TabPane tabId="1">
              <Row>
                <AAAPAge/>
              </Row>
            </TabPane>
            <TabPane tabId="2">
              <Row>
                <BBBPage/>
              </Row>
            </TabPane>
            <TabPane tabId="3">
              <Row>
                <CCCPage/>
              </Row>
            </TabPane>
          </TabContent>
        </div>
      </main>
    );
  }
}

export default withRouter(XYZPage);

Каждый из AAAPage, BBBPage и CCCPage - это компоненты, которые должны иметь некоторые предварительно заполненные выпадающие списки, которые я объявил в моем index.js ниже:

index.js

const store = configureStore();
store.dispatch(loadAAA());
store.dispatch(loadBBB());
store.dispatch(loadCCC());

render((
  <Provider store={store}>
    <BrowserRouter>
      <App />
    </BrowserRouter>
  </Provider>
), document.getElementById('app'));

loadAAA, loadBBB и loadCCC - все это thunks

Метод configureStore () таков:

export default function configureStore(initialState) {
  return createStore(
    rootReducer,
    initialState,
    composeWithDevTools(
      applyMiddleware(thunk, reduxImmutableStateInvariant()),
    )
  );
}

Чтобы сократить этот пост, я даю образец моей AAAPage какостальные имеют аналогичную структуру:

AAAPage.js:

class AAAPage extends React.Component {
  constructor(props, context) {
    super(props, context);
    this.state = {...};
  }

  componentWillReceiveProps(nextProps) {...}

  render() {
    [...]
    return (
      <Container fluid>
        <Row>
          <AAAInputForm
            // Data from Store is passed here 
          />
        </Row>
        {ChildComponent}
      </Container>
    );
  }
}

AAAPage.propTypes = {
  DATA: PropTypes.array
};

function mapStateToProps(state, ownProps) {
  let DATA = [];
  if (state.AAAReducer.length > 0) {
    DATA = state.AAAReducer;
  }

  return {
    DATA: DATA
  };
}

export default withRouter(connect(mapStateToProps)(AAAPage));

AAAReducer.js:

export default function AAAReducer(state=initialState.AAAList, action) {
  switch(action.type) {
    case types.LOAD_AAA_SUCCESS:
      return action.AAAList;

    default:
      return state;
  }
}

AAAAction.js:

export function loadAAASuccess(AAAList) {
  return {
    type: types.LOAD_AAA_SUCCESS,
    AAAList: AAAlList
  };
}

// thunk
export function loadAAA() {
  // A thunk will always return a function that accepts a dispatch
  return function(dispatch) {
    return apiCall("ALL").then(response => {
      dispatch(loadAAASuccess(response.data.AAA));
    }).catch(error => {
      throw(error);
    });
  };
}

initialState.js:

export default {
  AAAList: [],
  BBBList: [],
  CCCList: []
};

На данный момент я считаю, что предоставил достаточно информации для своего кода.Я следовал учебным пособиям при проектировании этого магазина, и я не уверен, почему, когда я перехожу от "/ abc / xyz" к "/ abc" и обратно, или когда я перехожу к "/ abc / xyz" из "/ abc", моймагазины пусты, хотя я вызвал метод loadAAA () в моем index.js.Все остальные страницы также затронуты.Однако, когда я нажимаю "/ abc / xyz" напрямую, мои магазины подключаются, и мои выпадающие списки заполняются.Что происходит?Это из-за моих методов жизненного цикла?

Я использую реагировать v15.6.2, redux v3.7.2 и redux-thunk v2.3.0.

Спасибо за руководство.

Ответы [ 2 ]

0 голосов
/ 20 февраля 2019

@ AKJ - @Анди Рэй сказал это правильно, но я хотел бы добавить, что componentDidMount - лучшее место для загрузки async вызовов, так как он вызывается после рендера, а около Store избыточное хранилище хранит данныедо тех пор, пока вы не обновите страницу после обновления, будет восстановлена ​​повторная инициализация хранилища, если вам нужно сохранить данные после обновления, попробуйте redux-persist

0 голосов
/ 20 февраля 2019

Вы вызываете только loadAAA на верхнем уровне index.js, который выполняется только один раз при загрузке вашей страницы.Если вы хотите отправлять его каждый раз при отображении страницы XYZPage, введите XYZ's componentDidMount

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