• Главная
  • Контакты
Подписаться:
  • Twitter
  • Facebook
  • RSS
  • VK
  • PushAll
logo

logo

  • Все
    • Положительные
    • Отрицательные
  • За сегодня
    • Положительные
    • Отрицательные
  • За вчера
    • Положительные
    • Отрицательные
  • За 3 дня
    • Положительные
    • Отрицательные
  • За неделю
    • Положительные
    • Отрицательные
  • За месяц
    • Положительные
    • Отрицательные
  • За год
    • Положительные
    • Отрицательные
  • Сортировка
    • По дате (возр)
    • По дате (убыв)
    • По рейтингу (возр)
    • По рейтингу (убыв)
    • По комментам (возр)
    • По комментам (убыв)
    • По просмотрам (возр)
    • По просмотрам (убыв)
Главная
  • Все
    • Положительные
    • Отрицательные
  • За сегодня
    • Положительные
    • Отрицательные
  • За вчера
    • Положительные
    • Отрицательные
  • За 3 дня
    • Положительные
    • Отрицательные
  • За неделю
    • Положительные
    • Отрицательные
  • За месяц
    • Положительные
    • Отрицательные
  • Главная
  • Как сделать жизнь Redux разработчика проще?

Как сделать жизнь Redux разработчика проще? -1

24.04.2017 13:39
master-7 20 2200 Источник
JavaScript*
Наверняка многие из вас, кто постоянно работают с React + Redux (а может не только с React), постоянно совершают множество однотипных действий. В оригинальном исполнении задача эта монотонная и включает в себя постоянное создание экшенов и редюсеров. Тем более, если приходится работать с какими-то экстраординарными кейсами, в игру включаются экшены с префиксами.

Ваш покорный слуга также испытал очень много батхерта страданий, пока работал по старинке, через switch > case, но я взглянул на задачу немного с другой стороны и привёл к единообразию это в более удобную функционально — объектную форму записи.

И так — после некоторого времени я (master-7) и мой коллега (one-more) попробовали справиться с этим страшным сном фронтэндера и создали весьма интересную библиотечку Redux-Utils.

Конечно же, мы попытались написать общепонятное и исчерпывающее ридми, но для затравки — несколько примеров в статье.

Одна из самых интересных фичей — это объектное создание редюсеров.

import {Reducer} from 'redux-util'
import {UserState} from 'types/UserState'

import {
    GET_USER_DATA_REQUEST,
    GET_USER_DATA_SUCCESS,
    GET_USER_DATA_FAIL
} from 'services/actionTypes'

const initialState: UserState = [];

export default Reducer(initialState, {
    [GET_USER_DATA_REQUEST]: () => null,
    [GET_USER_DATA_SUCCESS]: (state, action) => ({
        ...state,
        data: action.users
    }),
    [GET_USER_DATA_FAIL]: (state, action) => ({
        ...state,
        error: action.error
    })
});

Как вы можете видеть, код стал намного более читабельным по сравнению с записью вида:

import {Reducer} from 'redux-util'
import {UserState} from 'types/UserState'

import {
    GET_USER_DATA_REQUEST,
    GET_USER_DATA_SUCCESS,
    GET_USER_DATA_FAIL
} from 'services/actionTypes'

const initialState: UserState = [];

export default function Reducer(state = initialState, action) => {
    switch (action.type) {
      case GET_USER_DATA_REQUEST:
        return null;
      case GET_USER_DATA_REQUEST: 
        return {
        ...state,
        data: action.users
      };
      case GET_USER_DATA_FAIL: 
        return {
        ...state,
        error: action.error
      };
      default:
        return state;
}

Ну и киллер фича номер два — посмотрим на создание экшенов:

import {buildGenericActionCreator} from 'redux-util'

const START_LOADING = 'START_LOADING';
const END_LOADING = 'END_LOADING';

export const startLoadingActionCreator = buildGenericActionCreator(START_LOADING);
export const endLoadingActionCreator = buildGenericActionCreator(END_LOADING);

// ....

import {startLoadingActionCreator, endLoadingActionCreator} from 'loading-reducer'

const PREFIX = 'PREFIX';
const startLoading = startLoadingActionCreator(PREFIX);
const endLoading = endLoadingActionCreator(PREFIX);
export const loadUser = () => (dispatch: Dispatch) => {
    dispatch(startLoading());
    return api.fetchUser().then(
        response => {
            dispatch(
                loadUserDataAction(response)
            );
            dispatch(endLoading());
        }
    );
};

И еще много интересного вы можете найти в ридми проекта! Надеюсь, данная библиотека сделает вашу работу легче.
Будете ли вы использовать данную библиотеку?

Проголосовало 84 человека. Воздержалось 23 человека.

Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.

Поделиться с друзьями
-->

Комментарии (20)


  1. justboris
    24.04.2017 16:54
    #10188888
    +4

    И чем ваше решение лучше старого доброго redux-actions?


    1. pinebit
      24.04.2017 21:21
      #10189244

      Ну или redux sauce: https://github.com/skellock/reduxsauce


    1. comerc
      25.04.2017 02:17
      #10189528
      +1

      Есть "гораздо более лучший" вариант — redux-act


  1. xGromMx
    24.04.2017 20:03
    #10189136
    +4

    Как сделать жизнь Redux разработчика проще? Просто не использовать его


    1. kanstantsin
      25.04.2017 20:57
      #10190982

      Золотые слова. Вспоминаю как страшный сон эти тонны повторяющегося кода. Особенно доставляют константа на константе и спагетти из функций, которые аргументы функций, являющихся аргументами функций и т.д. по схеме. Как будто код какой-нибудь CMS из 2005 года.


      1. xGromMx
        25.04.2017 20:58
        #10190984

        и на что перешли?)


        1. kanstantsin
          25.04.2017 21:03
          #10190994

          Пока mobx, пока ок, если подумать над архитектурой прежде, чем начать писать :) Но кода стало меньше, появилось какое-никакое ООП, typescript опять же сильно помогает, уже почти можно жить :)


          1. xGromMx
            25.04.2017 21:12
            #10191002

            Ну mobx не про ООП =)


            1. kanstantsin
              26.04.2017 14:13
              #10191982
              +1

              mobx нет, но попытки писать в ооп-стиле с redux это пытка.


              1. justboris
                26.04.2017 14:27
                #10192032

                А зачем обязательно ООП?


                Есть и другие способы разбиения проекта на части, о которых написано в документации Redux


              1. raveclassic
                26.04.2017 16:10
                #10192254

                Правильно, потому что redux совсем не про ооп.


      1. raveclassic
        25.04.2017 23:18
        #10191154
        +1

        Вспоминаю как страшный сон эти тонны повторяющегося кода
        А можете пример, что у вас там так повторялось? Быть может, дело в том коде, а не в redux?
        Особенно доставляют константа на константе
        А что не так с константами?
        которые аргументы функций, являющихся аргументами функций и т.д. по схеме
        И что не так с ФВП?


        1. kanstantsin
          26.04.2017 14:19
          #10192004

          Я не хочу вступать в полемику, просто на проекте в ~25k строк кода со значительным кол-вом запросов к api размер, поддерживаемость, читаемость кода начинают иметь особое значение, поэтому отказ от redux оказался верным решением. На простых примерах типа todo все выглядит прилично, но на реальных проектах появляются проблемы. Только личный опыт :)


          1. raveclassic
            26.04.2017 16:09
            #10192252

            Возможно из-за того, что redux не дает каких-либо внятных рекомендаций по архитектуре сервисного и доменного слоев, предоставляя лишь паттерн для организации внутреннего взаимодействия UI. То, что экшены могут быть thunk'ами или promise'ами — не более чем сильное допущение и упрощение. И когда проект начинает разрастаться, становится понятно, что серьезному IO/эффектам не место ни в редьюсерах, ни в экшенах, ни вообще в redux, так как это не его задача (хоть redux и предоставляет возможность вставки middleware).

            Рекомендую посмотреть на redux-saga и redux-observable. Обе решают наболевшую проблему толстых экшенов с кучей копипасты, расширяемости и поддерживаемости. Саги только в качестве бонуса предоставляют тестируемость без каких-либо моков.


      1. comerc
        26.04.2017 11:06
        #10191592

        Вы просто не умеете его готовить. Константы не нужны совсем.


        https://github.com/comerc/yobr/blob/master/src/ducks/postForm.js


  1. raveclassic
    24.04.2017 20:35
    #10189176

    И как только люди не изворачиваются, лишь бы не писать return.


  1. pinebit
    24.04.2017 21:18
    #10189242
    +1

    Это уже наверное пятый улучшитель redux за месяц. Право же, не нужны они.
    Единственный тул который я сделал сам себе — связка redux action, saga и fetch, чтобы один dispatch запустил сагу, та вызвала API и все декларативно. Думал выложить это на гитхаб, но вовремя остановился.


    1. xGromMx
      25.04.2017 21:13
      #10191004

      уж лучше тогда redux-observable куда лучше саг


      1. raveclassic
        25.04.2017 23:11
        #10191150

        А чем лучше?


  1. avdept
    25.04.2017 11:20
    #10189914

    Зачем использовать редюкс если есть alt?

МЕТКИ

  • Хабы
  • Теги

JavaScript

redux

redux-utils

es6

javascript

СЕРВИСЫ
  • logo

    CloudLogs.ru - Облачное логирование

    • Храните логи вашего сервиса или приложения в облаке. Удобно просматривайте и анализируйте их.
Все публикации автора
  • Как сделать жизнь Redux разработчика проще? -1

    • 24.04.2017 13:39

    Как я писал web app angular + material и REST на Yii2 + webserver nginx +9

    • 11.01.2016 11:48

Подписка


ЛУЧШЕЕ

  • Сегодня
  • Вчера
  • Позавчера
05:19

Обвели вокруг пальца, или Как мы обманывали сканеры отпечатков +45

07:00

Среди кокса, шлака, валков и лебедей: день на металлургическом комбинате +38

15:18

Как мы в Авито нашли баланс между качеством и скоростью разработки на примере фичи рекомендаций Автотеки +30

08:00

Rust в ядре Linux: долгий путь от осторожных попыток к реальному применению +25

08:05

Традиционная аутентификация vs Биометрия +24

09:01

Загадочное трио: откуда берутся ошибки 502, 503 и 504 +19

13:01

Кросс-трекеры: ретро-музыка на современном ПК +17

08:41

Дайджест новостей о Земле и экологии за прошедшую неделю, о которых мы не писали +17

07:00

Опенсорс-библиотека Implicits от Яндекс Браузера: новый шаг в передаче зависимостей Swift +17

08:46

Почему в высшей лиге технологий и политики так много Евреев? +14

03:51

Физики предложили универсальный язык для мира электричества, чтобы завершить полуторавековой спор +13

09:25

В десятиэтажном доме людей бьет током, на стенах плесень, а УК все равно +12

08:55

Состоялся релиз российской ОС с локальным ИИ «МСВСфера» 10.1 +12

07:05

Боль в спине на удалёнке: сидеть нельзя подвигаться +12

11:17

Прогноз на 2026: люди, технологии, ИИ +11

07:23

Как WIP-лимиты останавливают хаос в задачах: пошаговое руководство для команд +11

12:55

Карьерные ожидания и стратегии IT-специалистов 2025-2026: что изменилось на рынке труда +10

09:39

Под корой «Бересты»: изучаем новый софт для бэкапа +10

05:01

Атаки на AI-агенты: примеры угроз и опыт участия в Agent Breaker CTF +10

11:53

Как мы пережили несколько мажорных обновлений Angular в B2B-платформе +8

15:12

Верховный Суд полностью отменил все предыдущие решения по делу Долиной: квартира остается за покупательницей +106

05:08

Память о глубине: топим литиевые аккумуляторы на 1500 м +103

05:27

Вайбанутым нет покоя +76

16:00

10 лет RUVDS в цифрах и 27 фактах +57

07:49

Value Object: как победить примитивную одержимость без DDD +54

13:01

Мороз по коже: LLM может оценить ваш код, а ИИ-компании — использовать это в своих целях +46

09:20

Изящные, ненормальные и удивительные алгоритмы на C +46

09:01

Коллекция полезных CSS фишек, которые вы редко используете +44

10:01

8 лучших RDP-клиентов 2025 года +35

07:01

Пять книг о российских технологических компаниях +33

09:59

Как приземляться в Top Gun: проверено реверс-инжинирингом +31

08:00

Декабрьская пятерка мини-ПК: компактные, мощные, необычные +31

21:05

Визуальный язык программирования в NebuLeet: эволюция и дизайн +29

08:50

Стилизация, часть 3. Превращение в стиль +29

14:44

Разработчики всё ещё путают JWT, JWKS, OAuth2 и OpenID Connect — разбираем на примерах. Часть 1 +26

08:42

Как оптимизировать код WebAssembly при помощи встраивания функций и деоптимизации +25

14:47

Когда исследования проводят не только исследователи — опыт Mail +24

17:34

Ваше Будущее… Моё… +23

14:38

Как «приватные» VPN-расширения слили переписки 8 миллионов пользователей с ChatGPT и Claude +23

14:26

Roadmap.sh: дорожные карты для изучения IT, 346k звёзд на GitHub +23

01:02

Как молодой девушке уехать на Яндекс.Такси в промзону и пропасть среди гаражей +260

13:01

Как я обнаружил скрытый микрофон в китайском NanoKVM +152

07:44

Почему учителя бегут из школ, а дети не хотят учиться — и как я это исправляю +114

09:01

Firefox — лучший мобильный браузер +86

13:33

Вход — бесплатно, выход — по подписке: разбор реального скама +73

13:03

Меня обвинили в том, что я — нейросеть +65

10:05

Это есть в Word, но мало кто об этом знает. Лайфхаки для продвинутого использования +45

08:00

Дешевых ПК и ноутбуков больше не будет: готовимся к 2026 году +38

19:17

Шпаргалка по настройке VPS на Debian/Ubuntu (2025) +35

07:59

Синдром бесконечного окна: почему 1 миллион токенов в LLM не решает ваши проблемы (пока) +34

04:57

Перетягивание замороженных активов с ЕС, а также космические дата-центры Илона Маска +31

10:32

Как подружить аудиторию старшего поколения с ИИ: результаты исследования +28

10:13

Flink Kubernetes operator: опыт построения стриминговой Big Data платформы +27

05:16

Как я уже 5 лет создаю свою макрос-клавиатуру. И почему не бросил этот проект +24

07:30

ИИ-агент: менеджер, которого у вас нет. Реальный кейс, как заменять манагеров в пиковые часы на Avito +22

05:42

Лучшие практики по настройке конфигураций в Kubernetes +21

11:19

Гайд: Как прострелить ноги unsafe кодом в C# +20

11:58

Как мы учили поиск понимать контекст: практическое руководство Купера для маркетплейсов +19

06:15

Rust, mmap и 10 миллионов пикселей: делаем производительный Log Viewer для VS Code +19

07:33

Как мы запускали «марсоход» на PostgreSQL: автоматизация кластеров в изолированной среде крупной компании +18

ОБСУЖДАЕМОЕ

  • Почему учителя бегут из школ, а дети не хотят учиться — и как я это исправляю +114

    • 443   97000

    Как молодой девушке уехать на Яндекс.Такси в промзону и пропасть среди гаражей +260

    • 254   41000

    Верховный Суд полностью отменил все предыдущие решения по делу Долиной: квартира остается за покупательницей +106

    • 237   34000

    Меня обвинили в том, что я — нейросеть +65

    • 197   14000

    Как я обнаружил скрытый микрофон в китайском NanoKVM +152

    • 142   178000

    Firefox — лучший мобильный браузер +86

    • 141   34000

    Как ИИ помогает проектировать базы данных -2

    • 81   9400

    C++, Rust и цветовая дифференциация воротничков +13

    • 78   8100

    Вайбанутым нет покоя +76

    • 67   18000

    Шпаргалка по настройке VPS на Debian/Ubuntu (2025) +35

    • 51   17000

    Память о глубине: топим литиевые аккумуляторы на 1500 м +103

    • 49   16000

    8 лучших RDP-клиентов 2025 года +35

    • 46   24000

    «Безработица не 10%, а 99%. Через 5 лет». Интервью доктора Романа Ямпольского, ученого по проблемам безопасности ИИ +5

    • 34   6600

    SQLSet — отделяем GO код от SQL-запросов +1

    • 33   7000

    Мороз по коже: LLM может оценить ваш код, а ИИ-компании — использовать это в своих целях +46

    • 31   17000
  • Главная
  • Контакты
© 2025. Все публикации принадлежат авторам.