2

我使用 felangel 的 bloc 库。我通过使用 mapEventToState 方法中的存储库来获取数据。如果存储库抛出异常,我想在全局异常处理程序上捕获它。

@override
Stream<MyState> mapEventToState(Event event) async* {
  if (event is MyEvent) {
    try {
      var data = await repository.fetchData();
      yield MyState(data);
    } catch (e) {
      //There may be many exceptions
    }
  }
}

有什么方法可以在没有 try-catch 块的情况下捕获异常,最佳实践是什么?

4

1 回答 1

0

您可以编写一个用于管理错误的实用程序。我为此写了一些东西。这对你来说可能是一个想法。

static String handleError(Error error) {
        String errorDescription = "";
        if (/*error is SomethingError*/) {
          switch (error.type) {
            case ErrorType.CANCEL:
              errorDescription = "ErrorType.CANCEL";
              break;
            case ErrorType.CONNECT_TIMEOUT:
              errorDescription = "ErrorType.CONNECT_TIMEOUT";
              break;
            case ErrorType.DEFAULT:
              errorDescription = "ErrorType.DEFAULT";
              break;
            case ErrorType.RECEIVE_TIMEOUT:
              errorDescription = "ErrorType.RECEIVE_TIMEOUT";
              break;
            case ErrorType.RESPONSE:
              switch (error.response.toString()) {
                case "usernamePasswordFail":
                  errorDescription = "usernamePasswordFail";
                  break;
                default:
                  errorDescription = "errorDescription";
 }, ${error.response.data ?? ''}";
                  break;
              }
              break;
            case ErrorType.SEND_TIMEOUT:
              errorDescription = "ErrorType.SEND_TIMEOUT";
              break;
          }
        } else {
          errorDescription = "somethingElseError";
        }
        return errorDescription;
      }
于 2019-12-20T12:57:23.443 回答