Лучший способ обрабатывать асинхронные события в флаттер-редуксе - PullRequest
0 голосов
/ 13 марта 2019

При создании приложения с использованием флаттера и редукса я столкнулся со следующей проблемой: как лучше всего обрабатывать сетевой запрос или любое асинхронное действие?

Контекст: выполнить асинхронный вызов, чтобы получитьстрока со стороны сервера (в моем случае это просто Future.delayed), когда запрос завершает, обновите состояние и просмотрите изменения в представлении.

Первый подход:

Создайте middlewareClass, который имеетфункция асинхронного вызова, которая будет ожидать завершения асинхронного события после его завершения, вызовет NextDispacther с новым действием, которое будет обработано в редукторах

 class UserTypeMiddleware extends MiddlewareClass<AppState> {

      @override
      void call(Store<AppState> store, action, NextDispatcher next) async{
        if (action is GetTitleAction) {
          String title = await Future<String>.delayed(Duration(seconds: 2), () {
            return "This is a title ";
          });
          next(UpdateTitleAction(title));
        } else {
          next(action);
        }
      }

    }

Второй подход:

Создание typedMiddlewareэто делает то же самое, но отправляет действие через store.dispatch

TypedMiddleware<AppState, GetTitleAction> userTypeMiddleware() =>
    TypedMiddleware<AppState, GetTitleAction>(_getTitle);

Future _getTitle(Store<AppState> store, GetTitleAction action, NextDispatcher next) async {
  String title = await Future<String>.delayed(Duration(seconds: 2), () {
    return "Flow.me este o aplicatie care va permite sa inchiriati un scooter ";
  });
  store.dispatch(UpdateTitleAction(title));
  next(action);
}

Третий подход:

Использовать redux_thunk

ThunkAction<AppState> updateTitleAction = (Store<AppState> store) async {
  String title = await Future<String>.delayed(Duration(seconds: 2), () {
    return "Flow.me este o aplicatie care va permite sa inchiriati un scooter ";
  });

  store.dispatch(UpdateTitleAction(title));
};

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

Разрушает ли это идею избыточности каким-либо образом, если я вызываю NextDispatcher в промежуточном программном обеспечении с задержкой от асинхронного запроса?Может ли это представлять проблему?

1 Ответ

1 голос
/ 22 марта 2019

Лучший способ обработать сетевой запрос или асинхронное действие - создать для него промежуточное программное обеспечение, никогда не обрабатывать асинхронное действие внутри редуктора (это избыточный антишаблон, редуктор должен быть чистыми функциями), или вы можете использовать перевождь-преобразователь .

...