Как использовать FutureBuilder внутри SliverList - PullRequest
0 голосов
/ 03 сентября 2018

Я хочу преобразовать ListView в CustomScrollView, поэтому мне нужно конвертировать FutureBuilder в SliverList.

Вот мой код:

class LatestNewsList extends StatefulWidget {
  @override
  _LatestNewsListState createState() => _LatestNewsListState();
}

class _LatestNewsListState extends State<LatestNewsList> {
  @override
  Widget build(BuildContext context) {
    return FutureBuilder<List<Data>>(
      future: getQuake(),
      builder: (context, snapshot){
        if(snapshot.hasError) print(snapshot.error);

        return snapshot.hasData
            ? NewsList(latestNews: snapshot.data,)
            : Center(child: CircularProgressIndicator());
      },
    );
  }
}

class NewsList extends StatelessWidget {
  final List<Data> latestNews;

  NewsList({this.latestNews});

  @override
  Widget build(BuildContext context) {



    return new ListView.builder(
        itemCount: latestNews.length,
        itemBuilder: (context, index){
          return new GestureDetector(
            onTap: () {
              Navigator.push(
                  context,
                  MaterialPageRoute(
                      builder: (context) => Browser(url: latestNews[index].post_link,)
                  )
              );
            },
            child: new LatestNewsItem(
              post_title: latestNews[index].post_title,
              post_link: latestNews[index].post_link,
              img_src: latestNews[index].img_src,
            ),
          );
        }
    );
  }
}

Как преобразовать эту же логику FutureBuilder в SliverList?

Ответы [ 2 ]

0 голосов
/ 16 мая 2019

Использовать SliverFillRemaining

Widget build(BuildContext context) {
return new Scaffold(
  body: CustomScrollView(
    slivers: <Widget>[
      SliverFillRemaining(
        child: FutureBuilder(
          future: getData(),
          builder: (context, snapshot) {
            if (snapshot.data == null)
              return new Container(
                child: Center(child: new CircularProgressIndicator()),
              );
            else
              return Text(snapshot.data.name);
          },
        ),
      )
    ],
  )
);

ИЛИ использовать SliverList

Widget build(BuildContext context) {
return new Scaffold(
  body: CustomScrollView(
    slivers: <Widget>[
         SliverList(
        delegate: SliverChildListDelegate([Container(
            child: FutureBuilder(
             future : getData(),
             builder: (C,snap){
                //do whatever you want
              }
          )
          )]),
        )
      ]
    )
  )
 }
0 голосов
/ 03 сентября 2018

Дети из CustomScrollView должны быть осколками, вы не можете использовать FutureBuilder.

Вместо этого перестройте CustomScrollView, когда будущее завершится:

// build fixed items outside of the FutureBuilder for efficiency
final someOtherSliver = SliverToBoxAdapter(...);

return FutureBuilder<List<Data>>(
  future: getQuake(), // this is a code smell. Make sure that the future is NOT recreated when build is called. Create the future in initState instead.
  builder: (context, snapshot){
    Widget newsListSliver;
    if(snapshot.hasData) {
      newsListSliver = SliverList(delegate: SliverChildBuilderDelegate(...))
    } else {
      newsListSliver = SliverToBoxAdapter(child: CircularProgressIndicator(),);
    }

    return CustomScrollView(
      slivers: <Widget>[
        someOtherSliver,
        newsListSliver
      ],
    );
  },
);

Если у вас есть несколько щепок, которые зависят от Future с или Stream с, вы можете связать строителей:

return FutureBuilder<..>(
  ...
  builder: (context, snapshot1) {
    return FutureBuilder<..>(
      ...
      builder: (context, snapshot2) {
        return CustomScrollView(...);
      }
    )
  }
)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...