Flutter ListView组件详解及其使用(Scrollable)

本文介绍了Flutter中ListView组件的使用方法,包括动态加载、缓冲区概念及ListTile、Scrollbar、RefreshIndicator等组件的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Flutter ListView组件详解及其使用(Scrollable)



前言

这篇文章将介绍Scrollable中的ListVIew组件,介绍动态加载(lazy loading)缓冲区概念,学习ListTile、Scrollbar、RefreshIndicator等组件


一、ListView

当我们遇到一个屏幕显示不下的情况,我们就需要使用到ListView来创捷一个可以滚动的面板。

body: ListView(
        children: <Widget>[
			// widget内容
        ],
      ),

那么问题来了 ,当我们不需要一下子把children全加载出来,而是需要一个缓冲区来储存数据来优化性能,我们就需要使用到LIstView.builder

ListView.builder

在这里插入图片描述
ListView.builder有一个必传参数itemBuilder,再介绍itemCount和cacheExtent常见的使用

body: ListView.builder(
          itemCount: 88,  // 数据最大容量,不定义就是默认无限
          cacheExtent: 2000, // 缓存区的空间,2000是高度不是2000个数据 具体的内容最好自己去操作一下,
          itemBuilder: (context,index){  // 此处的Context是父级的context
          print("$index");  
          //  也可以使用if和index来达到你想要的效果   if(index==?){}
            return
              index % 2 ==0
              ? Divider(thickness: 4,)  //DIvider是分割线
              : Container(
              color: Colors.blue[(index % 5) * 100],
              height: 100,
              alignment: Alignment.center,
              child: Text("$index"),
            );
          }
      ),

在这里插入图片描述

二、Scrollbar(滚动条)

在这里插入图片描述

代码如下(示例):

body: Scrollbar(
        radius: Radius.circular(9), 
        thickness: 4,
        isAlwaysShown: true,  // 总是显示滚动条
        child: ListView.builder(
          physics: BouncingScrollPhysics(),  // android和ios的样式不同,ios是自带Bouncing而android是ClampingScrollPhysics 当然还有always 和 never 这两个选项
          controller: _controller, // 当一个界面需要两个Scrollbar才需要2个_controller 。
          padding: const EdgeInsets.only(bottom: 140), // 这个应该不需要解释 字面意思,不过加给不同的widget效果都会不一样,所以知道是哪个widget加的padding就行了
          itemCount: 88, // 不同版本的flutter可能需要添加itemCount Scrollbar才会有效果
            itemExtent: 60, // 强制子类60的约束
            itemBuilder: (context,index){
            return ListTile( // 可以理解为专门为ListView服务的Contianer
              leading: Icon(Icons.person),
              title: Text("Name"),
              subtitle: Text("Subtitle"),
              trailing: IconButton(
                icon: Icon(Icons.delete_outline),
              ),
            );
              // return Container(
              //   height: index % 2 == 0 ? 150 : 50,
              //   color: index % 2 == 0 ? Colors.blue : Colors.blue[200],
              // );
            }
        ),
      ),

在这里插入图片描述

三、 RefreshIndicator(下拉刷新)

在这里插入图片描述
话不多说

代码如下(示例):

body: RefreshIndicator( // 当然 Scrollbar 和 RefreshIndicator 怎么互相套都可以实现
        onRefresh: () {  // 刷新后线程等待数据 
          return Future.delayed(Duration(seconds: 2));
        },
        child: ListView.builder( 
          physics: BouncingScrollPhysics(),
          itemCount: 200,
          controller: _controller,
          itemBuilder: (context,index){

          return Container(
            color: Colors.blue[index % 9 * 100],
              height: 100,
          );
        },
        ),
      ),

在这里插入图片描述


总结

文章质量有点粗糙 不过也适合初学者快速上手

这篇文章将介绍Scrollable中的ListVIew组件,介绍动态加载(lazy loading)缓冲区概念,学习ListTile、Scrollbar、RefreshIndicator等组件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值