Flutter之ExpansionTile可展开的列表

 源码

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.backgroundColor,//北京
    this.onExpansionChanged,//列表展开收起的回调函数
    this.children = const <Widget>[],//列表展开时显示的widget
    this.trailing,//标题右侧要展示的widget
    this.initiallyExpanded = false,//是否默认状态下展开
  }) : assert(initiallyExpanded != null),
}

demo:

import 'package:flutter/material.dart';


void main() => runApp(MyApp());

const CITY_NAMES = {
  '北京':['东城区','西城区','海淀区','朝阳区','石景山区','顺义区'],
  '上海':['黄浦区','徐汇区','长宁区','静安区','普陀区','闸北区'],
  '广州':['越秀','海珠','荔湾','天河','白云','黄埔','南沙'],
  '深圳':['南山','福田','罗湖','盐田','龙岗','宝安','龙华'],
  '杭州':['上城区','下城区','江干区','拱墅区','西湖区','滨江区'],
  '苏州':['姑苏区','吴中区','相城区','高新区','虎丘区','工业园区','吴江区'],
};

class MyApp extends StatelessWidget {



  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text("列表展开与收起"),
        ),
        body: Container(
          child: ListView(
            children: _buildList(),
          ),
        ),
      ),

    );
  }
  List<Widget> _buildList(){
    List<Widget> widgets = [];
    CITY_NAMES.keys.forEach((key){
      widgets.add(_item(key, CITY_NAMES[key]));
    });
    return widgets;
  }
  Widget _item(String city,List<String> subCities){
    return ExpansionTile(
      title: Text(
        city,
        style: TextStyle(color: Colors.black54,fontSize: 20),
      ),
      children: subCities.map((subCity)=>_buildSub(subCity)).toList(),
    );
  }

  Widget _buildSub(String subCity){
    //可以设置撑满宽度的盒子 称之为百分百布局
    return FractionallySizedBox(
      //宽度因子 1为百分百撑满
      widthFactor: 1,
      child: Container(
        height: 50,
        margin: EdgeInsets.only(bottom: 5),
        decoration: BoxDecoration(color: Colors.lightBlueAccent),
        child: Text(subCity),
      ),
    );
  }
}

效果:

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flutter中,下拉列表可以通过使用RefreshIndicator组件来实现。RefreshIndicator是一个可以在用户下拉列表时触发刷新操作的组件。通常,我们会将RefreshIndicator包裹在ListView组件中,以便在下拉时触发刷新操作。 下面是一个示例代码,展示了如何在Flutter中创建一个带有下拉刷新功能的列表: ```dart RefreshIndicator( onRefresh: _handleRefresh, child: ListView( children: _buildList(), ), ) ``` 在这个示例中,_handleRefresh是一个回调函数,用于处理刷新操作。_buildList()函数返回一个包含列表项的列表。 如果你想要在下拉列表时同时控制滚动,你可以使用ListView的controller属性来挂载一个ScrollController控制器。下面是一个示例代码: ```dart RefreshIndicator( onRefresh: _handleRefresh, child: ListView( controller: _scrollController, children: _buildList(), ), ) ``` 在这个示例中,_scrollController是一个ScrollController控制器,用于控制列表的滚动。 另外,如果你想要创建一个可展开的下拉列表,你可以使用ExpansionTile组件。下面是一个示例代码: ```dart ExpansionTile( title: Text('专业列表'), leading: Icon(Icons.list), children: <Widget>\[ ListTile( title: Text('title'), subtitle: Text('subtitle'), ), ListTile( title: Text('title'), subtitle: Text('subtitle'), ), ListTile( title: Text('title'), subtitle: Text('subtitle'), ), ListTile( title: Text('title'), subtitle: Text('subtitle'), ), \], ) ``` 在这个示例中,ExpansionTile组件包含一个标题和一个图标,当用户点击时,会展开显示子项。子项可以是任意的Widget,这里使用了多个ListTile作为子项。 希望这些示例代码能够帮助你在Flutter中创建下拉列表。如果还有其他问题,请随时提问。 #### 引用[.reference_title] - *1* *2* [flutter实现列表下拉刷新上拉加载](https://blog.csdn.net/a646639956/article/details/115336991)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [flutter两种写下拉列表的方式](https://blog.csdn.net/m0_47265814/article/details/111686265)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值