Передача действий

Функция connect позволяет обходиться без явного вызова dispatch. Общий принцип работы такой: в файл с компонентом импортируются необходимые действия и передаются вторым параметром в функцию connect.

// components/TasksBox.jsx
import React from 'react';
import { connect } from 'react-redux';
// Импортируем нужные действия
import * as actions from '../actions';

const mapStateToProps = state => {
  const props = {
    tasks: state.tasks,
  }
  return props;
};

// Формируем объект с действиями
const actionCreators = {
  addTask: actions.addTask,
};

class TasksBox extends React.Component {
  handleAddTask = (e) => {
    e.preventDefault();
    const { addTask, newTaskText } = this.props;
    addTask({ text: newTaskText });
  };

  render() {
    const { tasks } = this.props;
    // Отрисовываем задачи
    return <div>{/* logic with this.handleAddTask */}</div>;
  }
}

// Передаём действия вторым параметром
export default connect(mapStateToProps, actionCreators)(TasksBox);

Как видите, ничего не надо импортировать, всё есть в props. Технически действия оборачиваются в другие функции таким образом, что интерфейс работы остаётся прежним.

Для полного доступа к курсу, нужна профессиональная подписка

Профессиональная подписка откроет полный доступ ко всем курсам Хекслета, даст возможность обращаться за помощью к менторам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.

Получить доступ
115
курсов
892
упражнения
2241
час теории
3196
тестов

Зарегистрироваться

или войти в аккаунт

Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно.

  • 115 курсов, 2000+ часов теории
  • 800 практических заданий в браузере
  • 250 000 студентов

Нажимая кнопку «Зарегистрироваться», вы даёте своё согласие на обработку персональных данных в соответствии с «Политикой конфиденциальности» и соглашаетесь с «Условиями оказания услуг».

Наши выпускники работают в компаниях:

Логотип компании Альфа Банк
Логотип компании Rambler
Логотип компании Bookmate
Логотип компании Botmother

Есть вопрос или хотите участвовать в обсуждении?

Зарегистрируйтесь или войдите в свой аккаунт

Нажимая кнопку «Зарегистрироваться», вы даёте своё согласие на обработку персональных данных в соответствии с «Политикой конфиденциальности» и соглашаетесь с «Условиями оказания услуг».