freeCodeCamp/curriculum/challenges/chinese/03-front-end-libraries/redux/dispatch-an-action-event.md

1.9 KiB
Raw Blame History

id title challengeType forumTopicId dashedName
5a24c314108439a4d403614f 分发 Action Event 6 301442 dispatch-an-action-event

--description--

dispatch方法用于将 action 分派给 Redux store调用store.dispatch()将从 action creator 返回的值发送回 store。

action creator 返回一个具有 type 属性的对象,该属性指定已发生的 action然后该方法将 action 对象 dispatch 到 Redux store根据之前的挑战示例以下内容是等效的并且都 dispatch 类型为LOGIN的 action

store.dispatch(actionCreator());
store.dispatch({ type: 'LOGIN' });

--instructions--

代码编辑器中的 Redux store 具有初始化状态对象{login:'false'},还有一个名为loginAction()的 action creator它返回类型为LOGIN的 action然后通过调用dispatch方法将LOGIN的 action dispatch 给 Redux store并传递loginAction()创建的 action。

--hints--

调用函数loginAction应该返回一个对象{type:"LOGIN"}。

assert(loginAction().type === 'LOGIN');

store 应该初始化一个对象 {login:false}。

assert(store.getState().login === false);

store.dispatch()方法应该被用于 dispatch 一个类型为LOGIN的 action。

(getUserInput) =>
  assert(
    (function () {
      let noWhiteSpace = getUserInput('index').replace(/\s/g, '');
      return (
        noWhiteSpace.includes('store.dispatch(loginAction())') ||
        noWhiteSpace.includes("store.dispatch({type: 'LOGIN'})") === true
      );
    })()
  );

--seed--

--seed-contents--

const store = Redux.createStore(
  (state = {login: false}) => state
);

const loginAction = () => {
  return {
    type: 'LOGIN'
  }
};

// Dispatch the action here:

--solutions--

const store = Redux.createStore(
  (state = {login: false}) => state
);

const loginAction = () => {
  return {
    type: 'LOGIN'
  }
};

store.dispatch(loginAction());