前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每日tips:使用 ListView.separated 添加分隔符

每日tips:使用 ListView.separated 添加分隔符

作者头像
用户1974410
发布2022-09-20 16:55:44
8570
发布2022-09-20 16:55:44
举报
文章被收录于专栏:flutter开发精选

ListView.separated(https://api.flutter.dev/flutter/widgets/ListView/ListView.separated.html)是一个很方便的 API,可以使用它在列表项间添加分隔符。

可以看看官方文档的说明:

❝Separators only appear between list items: separator 0 appears after item 0 and the last separator appears before the last item. ❞

大意就是第一项上方和最后项下方没有分隔符。

在ios设备上,这种效果很明显,那我们如何在listview上第一和最后都加上分隔符呢。

我们可以通过追加一个不显示的第一项和最后一项,如下:

代码语言:javascript
复制
class ListViewWithAllSeparators<T> extends StatelessWidget {
  const ListViewWithAllSeparators({Key key, this.items, this.itemBuilder}) : super(key: key);
  final List<T> items;
  final Widget Function(BuildContext context, T item) itemBuilder;

  @override
  Widget build(BuildContext context) {
    return ListView.separated(
      itemCount: items.length + 2,
      separatorBuilder: (_, __) => Divider(height: 0.5),
      itemBuilder: (context, index) {
        if (index == 0 || index == items.length + 1) {
          return Container(); // zero height: not visible
        }
        return itemBuilder(context, items[index - 1]);
      },
    );
  }
}

Happy Coding!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-01-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 flutter开发精选 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档