当前位置:首页 > 技术知识 > 正文内容

Flutter 之 ListView(flutter框架)

maynowei10个月前 (08-02)技术知识165

在 Flutter 中,ListView 可以沿一个方向(垂直或水平方向)来排列其所有子 Widget,常被用于需要展示一组连续视图元素的场景

ListView 构造方法

  • ListView:仅适用于列表中含有少量元素的场景
  • ListView.build:适用于子 Widget 比较多的场景
  • ListView.separated:适用于需要设置分割线的场景

构造方法名 特点 使用场景 ListView 一次性创建好所有子 Widget 适用于展示少量连续子 Widget 的场景 ListView.build 提供了子 Widget 创建方法,仅在需要展示时才创建 适用于子 Widget 较多,且视觉效果呈现某种规律性的场景 ListView.separated 提供了子 Widget 创建方法,仅在需要展示时才创建,且提供了自定义分割线的功能 适用于子 Widget 较多,且视觉效果呈现某种规律性、每个子 Widget 之间需要分割线的场景

ListView

可以通过设置 children 参数,将所有子 Widget 包含到 listView 中,但这种创建方法要求提前将所有子 Widget 一次性创建好,而不是等到真正需要在屏幕上显示时才创建,即这种方法是导致性能下降。因此,这种方式只适合列表中含有少量元素的场景

class List extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
 return Scaffold(
 appBar: AppBar(
 title: Text("Android小白营"),
 ),
 body: ListView(
 children: <Widget>[
 ListTile(
 leading: Icon(
 Icons.home,
 color: Colors.cyan, // 图标颜色
 ),
 title: Text("首页"),
 selected: true, // 设置状态为选中状态
 ),
 ListTile(
 leading: Icon(
 Icons.add_shopping_cart,
 color: Colors.black54,
 ),
 title: Text("购物车"),
 ),
 ListTile(
 leading: Icon(
 Icons.account_circle,
 color: Colors.black54,
 ),
 title: Text("我的"),
 )
 ],
 ),
 );
 }
}

运行结果如下

ListView.builder

  • itemBuilder:列表项的创建方法。当列表滚动到相应位置时,ListView 会调用该方法创建对应的子 Widget
  • itemCount:列表项的数目。如果不设置或设置为空,则表示 ListView 为无限列表
  • itemExtent:列表项高度。可选参数,但对于定高的列表项元素,建议设置该参数的值(不设置时,ListView 会动态的根据子 Widget 创建完成后的结果,决定自身的视图高度,以及子 Widget 在 ListView 中的相对位置)
class ListBuild extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
 return Scaffold(
 body: ListView.builder(
 itemBuilder: (context, index) => ListTile(
 leading: Icon(Icons.adb),
 title: Text("下标" + index.toString()),
 ),
 itemExtent: 46, // 列表项高度
 itemCount: 50, //列表项总数,不设置为无限加载
 ),
 );
 }
}

运行结果如下

ListView.separatorBuilder

设置列表项之间的分隔线,可以根据下标设置不同的分隔线

class ListSeparated extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
 return Scaffold(
 appBar: AppBar(
 title: Text("Android小白营"),
 ),
 body: ListView.separated(
 itemBuilder: (context, index) => GestureDetector(
 child: ListTile(
 leading: Icon(Icons.adb),
 title: Text("下标" + index.toString()),
 ),
 onTap: () => Fluttertoast.showToast(msg: index.toString()), // 列表项点击事件
 ),
 separatorBuilder: (BuildContext context, index) {
 Divider divider;
 if (index % 2 == 0) {
 divider = Divider(
 thickness: 1, // 分隔线宽度
 height: 0,
 color: Colors.black12, // 分隔线颜色
 );
 } else {
 divider = Divider(
 thickness: 2,
 height: 0,
 color: Colors.deepOrangeAccent,
 );
 }
 return divider;
 },
 itemCount: 100,
 ),
 );
 }
}

运行效果如下

本文由博客一文多发平台 https://openwrite.cn?from=article_bottom 发布!

相关文章

分享我的产品策划流程,希望对你也有用

本文笔者梳理拆解了自己的产品策划流程,并给出了自己对各流程的思考,希望能够给你带来一定的启发。记得刚开始做产品出需求方案的时候,上来就开始画原型写文档,在写的过程中发现某个交互没想明白或者漏了一部分逻...

ExpandListView 的一种巧妙写法(三十的另一种写法)

ExpandListView大家估计也用的不少了,一般有需要展开的需求的时候,大家不约而同的都想到了它然后以前自己留过记录的一般都会找找以前自己的代码,没有记录习惯的就会百度、谷歌,这里吐槽一下,好几...

webview 渲染机制:硬件加速方式渲染的Android Web

webview 渲染是什么?webview 渲染是用于展现web页面的控件; webview 可以内嵌在移动端,实现前端的混合式开发,大多数混合式开发框架都是基于 webview 模式进行二次开发的w...

Django 官方推荐的姿势:类视图(django类视图和函数视图哪个好)

作者:HelloGitHub-追梦人物在开发网站的过程中,有一些视图函数虽然处理的对象不同,但是其大致的代码逻辑是一样的。比如一个博客和一个论坛,通常其首页都是展示一系列的文章列表或者帖子列表。对处理...

分析 Rust 程序的火焰图(rust火吗)

分析 Rust 程序的火焰图(Flame Graph)是定位性能瓶颈的核心手段,其核心是通过可视化的函数调用栈和时间分布,找到 CPU 耗时、内存分配、锁竞争等热点。以下是详细的分析方法和步骤,结合...

C++ 原子操作与锁的深度解析:为什么原子操作并非万金油?

大噶好,我是henry,今天来和大家浅浅聊一下为啥C++原子操作并非万能钥匙,原因有三,且听我娓娓道来:一、原子操作的线程安全性C++11 的 std::atomic 确实为单个变量的线程安全操作提供...