Flutter Refreshindicator перестраивает Listview.Builder после добавления новых элементов с помощью StreamBuilder

avatar
luxury
8 августа 2021 в 20:21
151
1
0

У меня есть RefreshIndicator, содержащийся в StreamBuilder. Каждый раз, когда в Streambuilder добавляются новые данные, RefreshIndicator перестраивает свой Listview.Builder, переходя в начало процесса.

StreamBuilder( поток: apiResultStream.stream, строитель: (Контекст BuildContext, моментальный снимок AsyncSnapshot) { если(моментальный снимок.hasError){ print("Ошибка"); } если(!Snapshot.hasData) {

            return  RefreshIndicator(
                onRefresh: () {
                  _apiResult=[];
                  return _loadMoreData(0);
                },
                child:snapshot.data.length == 0 ? Padding(
                  padding: const EdgeInsets.all(20.0),
                  child: Center(child: Text('No items', style: TextStyle(fontSize: 16.0, fontWeight: FontWeight.bold),)),
                ):SingleChildScrollView(
                    controller: scrollController,
                    physics: const AlwaysScrollableScrollPhysics(),
                    child:ListView.builder(
                    itemBuilder:(BuildContext ctxt, int index){
                      return InkWell(
                          
                          child:TripItem(key: ValueKey(snapshot.data[index].Id),item:snapshot.data[index])
                      );
                    }
                    ,itemCount:snapshot.data.length,
                    shrinkWrap: true,
                      physics: NeverScrollableScrollPhysics(),
                    key: UniqueKey(),


                ))

            );
     
Источник

Ответы (1)

avatar
luxury
8 августа 2021 в 20:27
0

Решение состоит в том, чтобы добавить GlobalKey к RefreshIndicator. Это предотвращает перестроение дочернего элемента RefreshIndicator, когда в StreamBuilder появляются новые данные.

StreamBuilder(
    stream: apiResultStream.stream,
    builder:
        (BuildContext context, AsyncSnapshot<dynamic> snapshot) {
          if(snapshot.hasError){
            print("has error");
          }
          if(!snapshot.hasData)
          {


       
            return  RefreshIndicator(
                key: _refreshIndicatorKey ,
                onRefresh: () {
                  _apiResult=[];
                  return _loadMoreData(0);
                },
                child:snapshot.data.length == 0 ? Padding(
                  padding: const EdgeInsets.all(20.0),
                  child: Center(child: Text('No items', style: 
                  TextStyle(fontSize: 16.0, fontWeight: 
                  FontWeight.bold),)),
                ):SingleChildScrollView(
                    controller: scrollController,
                    physics: const AlwaysScrollableScrollPhysics(),
                    child:ListView.builder(
                    itemBuilder:(BuildContext ctxt, int index){
                      return InkWell(
                          
                          child:TripItem(key: 
            ValueKey(snapshot.data[index].Id),item:snapshot.data[index])
                      );
                    }
                    ,itemCount:snapshot.data.length,
                    shrinkWrap: true,
                      physics: NeverScrollableScrollPhysics(),
                    key: UniqueKey(),


                ))

);