Ошибка состояния БЛОКА [ОШИБКА: flutter /lib/ui/ui_dart_state.cc(166)] Необработанное исключение: нереализованная ошибка

#http #flutter #dart #bloc

#http #flutter #dart #блок

Вопрос:

прежде всего, я получил ошибку, которая выглядит следующим образом

 I/flutter ( 3245): BLOC Start
I/flutter ( 3245): BLOC Start

════════ Exception caught by widgets library ═══════════════════════════════════════════════════════
The following NoSuchMethodError was thrown building BlocBuilder<StationBloc, StationState>(dirty, state: _BlocBuilderBaseState<StationBloc, StationState>#24ede):
The getter 'length' was called on null.
Receiver: null
Tried calling: length

The relevant error-causing widget was: 
  BlocBuilder<StationBloc, StationState> file:///C:/Users/junia/FlutterApp/airportstation/airport_station/lib/view/home_screen.dart:42:18
When the exception was thrown, this was the stack: 
#0      Object.noSuchMethod (dart:core-patch/object_patch.dart:51:5)
#1      _HomeScreenState.buildStationList (package:airport_station/view/home_screen.dart:79:30)
#2      _HomeScreenState.build.<anonymous closure> (package:airport_station/view/home_screen.dart:51:24)
#3      BlocBuilder.build (package:flutter_bloc/src/bloc_builder.dart:90:57)
#4      _BlocBuilderBaseState.build (package:flutter_bloc/src/bloc_builder.dart:162:48)
  

Затем я зашел в stackoverflow и нашел небольшое решение

 Widget buildStationList(List<AllFlight> allFlight) {
    return ListView.builder(
        itemCount: allFlight.length,
        itemBuilder: (BuildContext context, int index) {
          return Padding(
            padding: const EdgeInsets.all(8.0),
            child: InkWell(
              child: ListTile(
                title: Text(allFlight[index].airportName   ' - '   allFlight[index].countryName),
                subtitle: Text(allFlight[index].label),
              ),
            ),
          );
        }
    );
  

проблема включена itemCount: allFlight.length, , и я меняю ее на itemCount: allFlight?.length ?? 0,

после того, как я снова его запущу. все еще ошибка

 I/flutter ( 3245): BLOC Start
I/flutter ( 3245): BLOC Start
E/flutter ( 3245): [ERROR:flutter/lib/ui/ui_dart_state.cc(166)] Unhandled Exception: UnimplementedError
E/flutter ( 3245): #0      StationLoadedState.props (package:airport_station/bloc/station_state.dart:23:29)
E/flutter ( 3245): #1      Equatable.== (package:equatable/src/equatable.dart:50:18)
E/flutter ( 3245): #2      Bloc._bindEventsToStates.<anonymous closure> (package:bloc/src/bloc.dart:261:32)
E/flutter ( 3245): #3      _rootRunUnary (dart:async/zone.dart:1198:47)
E/flutter ( 3245): #4      _CustomZone.runUnary (dart:async/zone.dart:1100:19)
E/flutter ( 3245): #5      _CustomZone.runUnaryGuarded (dart:async/zone.dart:1005:7)
E/flutter ( 3245): #6      _BufferingStreamSubscription._sendData (dart:async/stream_impl.dart:357:11)
E/flutter ( 3245): #7      _BufferingStreamSubscription._add (dart:async/stream_impl.dart:285:7)
E/flutter ( 3245): #8      _SyncBroadcastStreamController._sendData (dart:async/broadcast_stream_controller.dart:385:25)
E/flutter ( 3245): #9      _BroadcastStreamController._add (dart:async/broadcast_stream_controller.dart:293:5)
E/flutter ( 3245): #10     _rootRunUnary (dart:async/zone.dart:1198:47)
E/flutter ( 3245): #11     _CustomZone.runUnary (dart:async/zone.dart:1100:19)
E/flutter ( 3245): #12     _CustomZone.runUnaryGuarded (dart:async/zone.dart:1005:7)
E/flutter ( 3245): #13     _BufferingStreamSubscription._sendData (dart:async/stream_impl.dart:357:11)
E/flutter ( 3245): #14     _BufferingStreamSubscription._add (dart:async/stream_impl.dart:285:7)
E/flutter ( 3245): #15     _ForwardingStreamSubscription._add (dart:async/stream_pipe.dart:127:11)
E/flutter ( 3245): #16     _MapStream._handleData (dart:async/stream_pipe.dart:224:10)
E/flutter ( 3245): #17     _ForwardingStreamSubscription._handleData (dart:async/stream_pipe.dart:157:13)
E/flutter ( 3245): #18     _rootRunUnary (dart:async/zone.dart:1198:47)
E/flutter ( 3245): #19     _CustomZone.runUnary (dart:async/zone.dart:1100:19)
E/flutter ( 3245): #20     _CustomZone.runUnaryGuarded (dart:async/zone.dart:1005:7)
E/flutter ( 3245): #21     _BufferingStreamSubscription._sendData (dart:async/stream_impl.dart:357:11)
E/flutter ( 3245): #22     _DelayedData.perform (dart:async/stream_impl.dart:611:14)
E/flutter ( 3245): #23     _StreamImplEvents.handleNext (dart:async/stream_impl.dart:730:11)
E/flutter ( 3245): #24     _PendingEvents.schedule.<anonymous closure> (dart:async/stream_impl.dart:687:7)
E/flutter ( 3245): #25     _rootRun (dart:async/zone.dart:1182:47)
E/flutter ( 3245): #26     _CustomZone.run (dart:async/zone.dart:1093:19)
E/flutter ( 3245): #27     _CustomZone.runGuarded (dart:async/zone.dart:997:7)
E/flutter ( 3245): #28     _CustomZone.bindCallbackGuarded.<anonymous closure> (dart:async/zone.dart:1037:23)
E/flutter ( 3245): #29     _rootRun (dart:async/zone.dart:1190:13)
E/flutter ( 3245): #30     _CustomZone.run (dart:async/zone.dart:1093:19)
E/flutter ( 3245): #31     _CustomZone.runGuarded (dart:async/zone.dart:997:7)
E/flutter ( 3245): #32     _CustomZone.bindCallbackGuarded.<anonymous closure> (dart:async/zone.dart:1037:23)
E/flutter ( 3245): #33     _microtaskLoop (dart:async/schedule_microtask.dart:41:21)
E/flutter ( 3245): #34     _startMicrotaskLoop (dart:async/schedule_microtask.dart:50:5)
E/flutter ( 3245): 
  

мой bloc_state.dart выглядит следующим образом

 ...

class StationLoadedState extends StationState {
  final List<AllFlight> allFlight;

  StationLoadedState({ @required this.allFlight });

  @override
  List<Object> get props => throw UnimplementedError();
}

...
  

и blockbuilder

 class _HomeScreenState extends State<HomeScreen> {
  StationBloc stationBloc;

  @override
  void initState() {
    super.initState();
    stationBloc = BlocProvider.of(context);
    stationBloc.add(FetchStationEvent());
  }

...

body: Container(
        child: BlocListener<StationBloc, StationState>(
          listener: (context, state) {
            if (state is StationErrorState) {
              print(state.message);
            }
          },
          child: BlocBuilder<StationBloc, StationState>(
            builder: (context, state) {
              print('BLOC Start');
              if (state is StationInitialState) {
                return buildLoading();
              } else if (state is StationLoadingState) {
                return buildLoading();
              } else if (state is StationLoadedState) {
                return buildStationList(state.allFlight);
              } else if (state is StationErrorState) {
                return buildError(state.message);
              }
            },
          ),
        ),
      ),
...
  

ответ json успешно возвращен, когда я пытаюсь напечатать его в http-ответе. кто-нибудь знал, в чем проблема?

Ответ №1:

У BlocState есть средство получения «props», которое должно возвращать массив переменных для сравнения состояний друг с другом. Когда вы выдаете одно и то же состояние 2 раза подряд, он будет сравнивать их, используя эти реквизиты, и если это то же состояние, что и текущее — блок не выдаст его снова (это работает по умолчанию, когда вы используете Equatable).

В вашем коде выше у вас есть это:

 class StationLoadedState extends StationState {
  final List<AllFlight> allFlight;

  StationLoadedState({ @required this.allFlight });

  @override
  List<Object> get props => throw UnimplementedError();
}
  

Он выдает UnimplementedError при вызове реквизитов. Измените его на массив с параметрами вашего состояния.

 class StationLoadedState extends StationState {
  final List<AllFlight> allFlight;

  StationLoadedState({ @required this.allFlight });

  @override
  List<Object> get props => [allFlight];
}
  

Комментарии:

1. Я уже пробовал эти изменения, но они ничего не возвращают. Мой экран пуст, и в моем logcat нет ошибки

2. Упс, извините, не заметил, что у состояния есть параметр. Исправлен код. Вы когда-нибудь вызывали код, который на самом деле выдает StationLoadedState (в вашем сообщении нет примера блока)? Также обязательно закройте страницу, использующую этот блок, и откройте ее снова или перезапустите ваше приложение, чтобы изменения вступили в силу.

3. Спасибо @Thepeanut , код работает правильно, не ожидал, что мне просто нужно поместить ‘allFlight’ в параметр. Спасибо за помощь, кстати, я уже вызываю yield внутри файла блока.