【问题标题】:Itembuilder doesn't execute in streambuilder, when updating data in firestore更新firestore中的数据时,Itembuilder不会在streambuilder中执行
【发布时间】:2020-02-07 04:39:25
【问题描述】:

当我第一次启动应用程序时,它会将所有项目加载到动画列表中。但是当我将一个项目添加到 firestore 时,streambuilder 会意识到发生了一些事情。但它不会执行 itembuilder,因此不会出现新项目。但是,如果我重新启动应用程序,将加载新项目。如果我只是更改 firestore 数据库中现有项目的名称,它将毫无问题地重建。

当我更新一个项目时。我必须获取任务地图并将其替换为具有该项目的新副本并将其发布/更新到 Firestore。

我已经尝试了所有我能想到的方法,但不明白为什么会发生这种情况。 我已在 itembuilder 中打印,可以看到它不会在更新时执行。

Widget _buildTasksList() {

    return new Expanded(
      child: new StreamBuilder(
      stream: Firestore.instance
          .collection("lists")
          .document(tasklist.postID)
          .snapshots(),
      builder: (BuildContext context, AsyncSnapshot snapshot) {
        if (!snapshot.hasData) {
          return new Text("Loading");
        }
        var listdata = snapshot.data;
        tasklist.tasks = listdata['tasks'];
        tasklist.owners = listdata['owners'];
        tasklist.sorter = listdata['sorter'];
        return new AnimatedList(
          initialItemCount: convertToTaskList(listdata['tasks']).length,
          key: _listKey,
          itemBuilder: (context, index, animation) {
            return new TaskRow(
              task: this.listModel[index],
              animation: animation,
              listModel: this.listModel,
              tasklist: tasklist,
              onChange: () => _onChange(this.listModel[index]),
            );
          },
        );
      },
    )
    );
  }

【问题讨论】:

    标签: flutter stream-builder flutter-animatedlist


    【解决方案1】:

    通过重置我的 _listKey 让它工作,在动画列表之前添加了这个。 _listKey = null; _listKey = new GlobalKey();

    【讨论】:

      猜你喜欢
      • 2022-11-17
      • 2020-07-02
      • 2021-02-07
      • 1970-01-01
      • 1970-01-01
      • 2020-06-14
      • 2021-10-09
      • 2020-03-26
      • 2019-08-19
      相关资源
      最近更新 更多