产生新状态后颤振状态不更新

时间:2020-04-21 21:25:18

标签: flutter bloc

我在flutter应用程序中使用bloc,我的问题是在产生新状态时视图未更新。 我想将新消息添加到我的消息列表中。并且我使用新数据产生了相同的状态,但是在向列表中添加新消息后我的视图没有更新。 团体:

class ChatBloc extends Bloc<ChatEvent, ChatState> {
  @override
  ChatState get initialState => ChatInitial();

  @override
  Stream<ChatState> mapEventToState(ChatEvent event) async* {
   if (event is AddToMessages) {
      yield* _mapAddToMessagesEventToState(event.chatMessage);
    }
  }

  Stream<ChatState> _mapAddToMessagesEventToState(ChatMessage chatMessage) async* {
    List<ChatMessage> chatMessages = (state as DataLoaded).chatMessages;
    chatMessages.insert(0, chatMessage);
    yield DataLoaded(chatMessages: chatMessages);
  }
}

事件:

abstract class ChatEvent extends Equatable {}
class AddToMessages extends ChatEvent {
  final ChatMessage chatMessage;
  AddToMessages({@required this.chatMessage});
  @override
  List<Object> get props => [chatMessage];
}

状态:

abstract class ChatState extends Equatable {
  const ChatState();
}

class ChatInitial extends ChatState {
  const ChatInitial();

  @override
  List<Object> get props => [];
}
class DataLoaded extends ChatState {
  final List<ChatMessage> chatMessages;
  const DataLoaded({this.chatMessages});

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

并查看:

class ChatScreen extends StatelessWidget {
  Widget createBody(ChatState state, BuildContext context) {
    if (state is DataLoaded) {
      return Column(
        children: <Widget>[
          MessagesList(
            messages: state.chatMessages,
          ),
          SendBar(
            onMessage: (message) => BlocProvider.of<ChatBloc>(context).add(
              AddToMessages(
                chatMessage: ChatMessage(
                  chatMessageType: ChatMessageType.TEXT,
                  dateTime: DateTime.now(),
                  message: message,
                  userId: store.state.userProfile.id,
                ),
              ),
            ),
          ),
        ],
      );
    } else {
      return Container();
    }
  }

  @override
  Widget build(BuildContext context) {
    return BlocProvider<ChatBloc>(
      create: (context) {
        return ChatBloc(chatRepository: chatRepository)..add(DataLoaded(chatMessages: []));
      },
      child: BlocListener<ChatBloc, ChatState>(
        listener: (context, state) async {},
        child: BlocBuilder<ChatBloc, ChatState>(
          builder: (context, state) {
            return Scaffold(
              body: createBody(state, context),
            );
          },
        ),
      ),
    );
  }
}

当我添加新消息时,视图不会更新。 我的错误在哪里。

2 个答案:

答案 0 :(得分:1)

编辑:毕竟,这是因为您使用的是平等状态,并且因为在发出新状态时,您只是通过在其中插入一条消息来更改旧状态的列表,然后发出具有相同列表的旧状态,因此,当bloc比较这两个状态时,并且由于状态类扩展为等值的,因此bloc认为它们相同且不发出状态

解决方案:删除等值的

使用不可变列表,因此您可以发出一个新属性,该属性与先前的属性不同,并且可以通过bloc进行区分

答案 1 :(得分:0)

某些内容的列表在 Equatable 中无法正常工作。即使 List 元素不相同,它也总是返回 true。

所以我有一个解决方法。我添加了另一个 List 属性和一个 bool 属性来帮助在 State of Bloc 拥有大量属性的人。

class DataLoaded extends ChatState {
  final List<Member> roomMembers;
  final List<ChatMessage> chatMessages;
  final bool isOpen;

  
  final List<Object> allElements;

  DataLoaded({this.chatMessages, this.roomMembers, this.isOpen}) 
    : allElements = [...chatMessages, ...roomMembers, isOpen];

  @override
  List<Object> get props => allElements;
}

我希望它能帮助你,它对我有用:)

相关问题