颤抖如何在数据更改的情况下更新Listview.builder

时间:2020-09-15 15:49:37

标签: flutter listview auto-update stream-builder

我正在使用Flutter中的 ListView.builder 。现在一切正常,在回调方法中有以下几行代码:

@override
void initState(){
  items = new List();
  for(int index = 0; index < dataList.length; index++){
    items.add(...creating widget ..);
  }
}

 @override
  Widget build(BuildContext context) {
    return Container(
    child: ListView.builder(
        scrollDirection: Axis.vertical,
       shrinkWrap: true,
       itemCount: dataList.length,
       itemBuilder: (BuildContext context, int index) {
          return Container(
            width: width,
            height: 160 ,
            key: UniqueKey(),
            padding: EdgeInsets.all(10),
            child: items[index],
          );
        },
      ),
    );
  }

问题是 dataList 的数据更新时,如果数据值已更新,已删除,我应该如何实现此列表以使列表更新 UI 或地点已更改。 StreamBuilder是解决方案吗?

1 个答案:

答案 0 :(得分:2)

如果它在不断变化,请使用rope

例如:https://bendyworks.com/blog/a-month-of-flutter-rendering-a-list-view-with-stream-builder

否则,您可以使用StreamBuilder

例如:https://medium.com/nonstopio/flutter-future-builder-with-list-view-builder-d7212314e8c9

OR

如果dataList在应用程序内部更改(删除/更新),则调用FutureBuilder,这将更新setState()