Flutter开发之ListView添加HeaderView和FooterView(38)

参考文章:Flutter ListView如何添加HeaderView和FooterView

flutter的ListView添加HeaderView和FooterView使用CustomScrollView + SliverToBoxAdapter + SliverList来实现。

页面完整代码:

import 'package:flutter/material.dart';

class ListViewAddHeaderView extends StatelessWidget {
  // 列表项
  Widget _buildListItem(BuildContext context, int index){
    return ListTile(
        title: Text('list tile index $index')
    );
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('List Add HeaderView'),
      ),
      body: CustomScrollView(
        slivers: [
          // 如果不是Sliver家族的Widget,需要使用SliverToBoxAdapter做层包裹
          SliverToBoxAdapter(
            child: Container(
              height: 120,
              color: Colors.green,
              child: Text('HeaderView',style: TextStyle(color: Colors.red,fontSize: 20),),
            ),
          ),
          // 当列表项高度固定时,使用 SliverFixedExtendList 比 SliverList 具有更高的性能
          SliverFixedExtentList(
              delegate: SliverChildBuilderDelegate(_buildListItem, childCount: 18),
              itemExtent: 48.0
          ),

          SliverToBoxAdapter(
            child: Container(
              height: 120,
              color: Colors.green,
              child: Text('FotterView',style: TextStyle(color: Colors.red,fontSize: 20),),
            ),
          ),

        ],
      ),
    );
  }
}

运行效果

Flutter开发之ListView添加HeaderView和FooterView(38)_第1张图片

成功添加了头和尾部。

你可能感兴趣的:(Flutter开发教程)