【Flutter】ExpansionTile 可折叠列表

简介: 【Flutter】ExpansionTile 可折叠列表

文章目录

一、ExpansionTile 构造方法

二、完整代码示例






一、ExpansionTile 构造方法


下面是 ExpansionTile 的构造方法 ;


其中 required this.title 是必须要设置的参数 ;


class ExpansionTile extends StatefulWidget {
  /// Creates a single-line [ListTile] with a trailing button that expands or collapses
  /// the tile to reveal or hide the [children]. The [initiallyExpanded] property must
  /// be non-null.
  const ExpansionTile({
    Key? key,
    this.leading,      // 标题左侧的 Widget 组件
    required this.title,    // 展示的列表标题 Widget 
    this.subtitle,      // 子标题 
    this.onExpansionChanged,    // 列表 展开/折叠 回调函数
    this.children = const <Widget>[], // 列表展示时显示的 Widget 组件集合
    this.trailing,      // 标题右侧的 Widget 组件
    this.initiallyExpanded = false,  // 默认状态下是否展开 , 默认不展开 
    this.maintainState = false,
    this.tilePadding,
    this.expandedCrossAxisAlignment,
    this.expandedAlignment,
    this.childrenPadding,
    this.backgroundColor,    // 背景沿着
    this.collapsedBackgroundColor,
    this.textColor,
    this.collapsedTextColor,
    this.iconColor,
    this.collapsedIconColor,
  }) : assert(initiallyExpanded != null),
       assert(maintainState != null),
       assert(
       expandedCrossAxisAlignment != CrossAxisAlignment.baseline,
       'CrossAxisAlignment.baseline is not supported since the expanded children '
           'are aligned in a column, not a row. Try to use another constant.',
       ),
       super(key: key);
}





二、完整代码示例


import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
const NAMES = {
  '三十六天罡' : [ '宋江', '卢俊义', '吴用', '公孙胜', '关胜' ],
  '七十二地煞' : [ '陈继真', '黄景元', '贾成', '呼颜', '鲁修德' ]
};
void main() {
  runApp(MyApp());
}
class MyApp extends StatefulWidget {
  const MyApp({Key? key}) : super(key: key);
  @override
  _MyAppState createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
  @override
  Widget build(BuildContext context) {
    /// 材料设计主题
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          /// 标题组件
          title: Text("ListView 示例"),
        ),
        /// 列表组件
        body: ListView(
          children: _buildList(),
        ),
      ),
    );
  }
  /// 创建列表 , 每个元素都是一个 ExpansionTile 组件
  List<Widget> _buildList(){
    List<Widget> widgets = [];
    NAMES.keys.forEach((key) {
      widgets.add(_generateExpansionTileWidget(key, NAMES[key]));
    });
    return widgets;
  }
  /// 生成 ExpansionTile 组件 , children 是 List<Widget> 组件
  Widget _generateExpansionTileWidget(tittle, List<String>? names){
    return ExpansionTile(
      title: Text(
        tittle,
        style: TextStyle(
          color: Colors.black54,
          fontSize: 20
        ),
      ),
      children: names!.map((name) => _generateWidget(name)).toList(),
    );
  }
  /// 生成 ExpansionTile 下的 ListView 的单个组件
  Widget _generateWidget(name){
    /// 使用该组件可以使宽度撑满
    return FractionallySizedBox(
      widthFactor: 1,
      child: Container(
        height: 80,
        //width: 80,
        margin: EdgeInsets.only(bottom: 5),
        //margin: EdgeInsets.only(right: 5),
        alignment: Alignment.center,
        decoration: BoxDecoration(color: Colors.black),
        child: Text(
          name,
          style: TextStyle(
              color: Colors.yellowAccent,
              fontSize: 20
          ),
        ),
      ),
    );
  }
}


执行效果 :


image.png




目录
相关文章
|
1天前
Flutter 列表学习(listview,gridview,ExpansionTile,ScrollController,RefreshIndicator)
Flutter 列表学习(listview,gridview,ExpansionTile,ScrollController,RefreshIndicator)
|
2月前
|
前端开发 UED 开发者
【Flutter前端技术开发专栏】Flutter中的列表与滚动视图优化
【4月更文挑战第30天】Flutter开发中,优化列表和滚动视图至关重要。本文介绍了几种优化方法:1) 使用`ListView.builder`和`GridView.builder`实现懒加载;2) 复用子组件以减少实例创建;3) 利用`CustomScrollView`和`Slivers`提升滚动性能;4) 通过`NotificationListener`监听滚动事件;5) 使用`KeepAlive`保持列表项状态。掌握这些技巧能提升应用性能和用户体验。
【Flutter前端技术开发专栏】Flutter中的列表与滚动视图优化
|
2月前
|
缓存
使用Riverpod在Flutter中创建Todo列表
学习如何使用Riverpod在Flutter中构建一个功能完整的Todo列表应用。通过Consumer组件、ConsumerStatefulWidget类、ref.read方法和provider build重写,了解Riverpod的状态管理和更新状态机制。
299 7
使用Riverpod在Flutter中创建Todo列表
|
2月前
|
存储 缓存 监控
【Flutter前端技术开发专栏】Flutter中的列表滚动性能优化
【4月更文挑战第30天】本文探讨了Flutter中优化列表滚动性能的策略。建议使用`ListView.builder`以节省内存,避免一次性渲染所有列表项。为防止列表项重建,可使用`UniqueKey`或`ObjectKey`。缓存已渲染项、减少不必要的重绘和异步加载大数据集也是关键。此外,选择轻量级组件,如`StatelessWidget`,并利用Flutter DevTools监控性能以识别和解决瓶颈。持续测试和调整以提升用户体验。
【Flutter前端技术开发专栏】Flutter中的列表滚动性能优化
|
2月前
|
前端开发 数据处理
【Flutter 前端技术开发专栏】Flutter 中的滚动性能优化与无限列表实现
【4月更文挑战第30天】本文探讨了 Flutter 中的滚动性能优化和无限列表实现。关键点包括:1) 滚动性能直接影响用户满意度,优化可提升响应速度;2) 影响因素有布局复杂度、频繁重绘和数据处理;3) 优化措施包括懒加载、简化布局、减少不必要的重绘和高效处理数据;4) 无限列表通过监听滚动位置,动态加载新数据;5) 实现时注意加载策略、数据处理效率和内存管理。案例分析和总结强调了优化在实际开发中的重要性。
【Flutter 前端技术开发专栏】Flutter 中的滚动性能优化与无限列表实现
|
Android开发
Flutter一天一控件之ListTile(列表的实现)
Flutter一天一控件之ListTile(列表的实现)
|
iOS开发 容器
重识Flutter 在不同的滑动列表场景,请选择合适的Slivers - part2
在Flutter中,碰到复杂的、不同的滑动业务场景,若是选择了一个合适的Slivers组件,那么我认为问题会变得简单!
重识Flutter 在不同的滑动列表场景,请选择合适的Slivers - part2
|
测试技术 容器
Flutter Web网站之Markdown展示与博客列表
Flutter Web网站之Markdown展示与博客列表
195 0
Flutter Web网站之Markdown展示与博客列表
|
Dart IDE 开发工具
Flutter 图文并茂列表实现
Flutter使用 ListView 完成列表的构建,界面实现的关键工作实际是布局子元素的拆分。剩下的实现方式存在多种,看各人喜好。但是,需要注意避免过多嵌套导致代码不好维护,并需要提高复用性。
826 2
Flutter 图文并茂列表实现
Flutter之 动态列表
Flutter之 动态列表
107 0
Flutter之 动态列表