文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

flutter底部弹出BottomSheet怎么实现

2023-06-29 15:58

关注

本篇内容介绍了“flutter底部弹出BottomSheet怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

效果图:

flutter底部弹出BottomSheet怎么实现

ModalBottomSheet

这个ModalBottomSheet就是类似一个Dialog,有一个半透明的背景层,然后上面显示你自定义的内容。 用法非常简单,Flutter提供了一个showModalBottomSheet的方法弹出一个BottomSheet。

实现代码:

class AddExpense extends StatefulWidget {  @override  State<StatefulWidget> createState() => _AddExpensePage();}class _AddExpensePage extends State<AddExpense> {  List<Search> typeList = List<Search>();  Search _search;  bool _typeCheck = false;  @override  void initState() {    // TODO: implement initState    super.initState();    _loadType();  }  @override  Widget build(BuildContext context) {    // TODO: implement build    return  Column(      children: <Widget>[        Card(          child: Row(            children: <Widget>[              SizedBox(                width: 16.0,              ),              Text('报销类型:', style: TextStyle(fontSize: 16)),              Expanded(                child: ListTile(                  title: Text(                    _search.code ?? "报销类型",                  ),                  trailing: _typeCheck                      ? Icon(Icons.keyboard_arrow_up)                      : Icon(Icons.keyboard_arrow_down),                  onTap: () {                    setState(() {                      _typeCheck = !_typeCheck;                    });                    showModalBottomSheet(                      context: context,                      builder: (BuildContext context) {                        return ListView.separated(                          itemCount: typeList.length,                          separatorBuilder: (context, index) {                            return Divider();                          },                          itemBuilder: (context, index) {                            return ListTile(                              title: Text(typeList[index].code),                              trailing: Offstage(                                offstage:                                typeList[index].check ? false : true,                                child: Icon(Icons.check),                              ),                              onTap: () {                                for (int i = 0; i < typeList.length; i++) {                                  i != index                                      ? typeList[i].check = false                                      : typeList[i].check = true;                                }                                _search = typeList[index];                                Navigator.pop(context);                              },                            );                          },                        );                      },                    ).then((val) {                      setState(() {                        _typeCheck = !_typeCheck;                      });                    });                  },                ),              )            ],          ),        ),      ],    );     }  void _loadType() {    String jsonData =        '[{"code":"差旅费报销单","check":true},{"code":"一般费用报销单","check":false},{"code":"因公临时出国(境)支出表","check":false},{"code":"药费报销单","check":false},{"code":"合同付款审批表","check":false},{"code":"工资系统专用报销表","check":false}]';    List<dynamic> list = json.decode(jsonData);    list.forEach((element) {      Search search = Search.fromJson(element);      if (search.check) {        setState(() {          _search = search;        });      }      typeList.add(search);    });  }}

“flutter底部弹出BottomSheet怎么实现”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯