Flutter UI实现侧拉抽屉菜单
在移动开发中,我们可以通过底部导航栏、标签页或是侧边抽屉菜单来实现导航。这是在小屏幕上可以充分利用空间。我们设计不仅要实用而且要有趣,这样才算得上好的 UI 设计。这件我们在 Scaffold 通常是上下结构,头部是标题栏下面主界面。
@override
Widget build(BuildContext context) {
// TODO: implement build
return Scaffold(
appBar: AppBar(title: Text(title),),
body: Center(child: Text('$title Demo'),),
),
),
);Scaffold 除了 appBar 和 body 属性以为还有 drawer 属性方便我们定义侧边抽屉。
@override
Widget build(BuildContext context) {
// TODO: implement build
return Scaffold(
appBar: AppBar(title: Text(title),),
body: Center(child: Text('$title Demo'),),
drawer: Drawer(
)
),
),
);这样便可以在 child 为侧拉抽屉添加内容,内容是添加一个列表。DrawerHeader 添加标题栏。然后 decoration 中添加背景颜色。然后通过 ListTile 组件来添加一条一条内容
child: ListView(
padding: EdgeInsets.zero,
children: <Widget>[
DrawerHeader(
child: Text('$title Demo'),
decoration: BoxDecoration(
color: Colors.blue
),
),
ListTile(
title: Text("React"),
onTap: (){
Navigator.pop(context);
},
),
ListTile(
title: Text("Vue"),
onTap: (){
Navigator.pop(context);
},
)
],
),为 ListTile 添加 onTap 事件来通过 Navigator 返回到主界面。
ListTile(
title: Text("Vue"),
onTap: (){
Navigator.pop(context);
},
)完整代码
import 'package:flutter/material.dart';
class DrawerApp extends StatelessWidget{
final appTitle = "侧滑抽屉";
@override
Widget build(BuildContext context) {
// TODO: implement build
return MaterialApp(
title: appTitle,
home: MyHomePage(title:appTitle),
);
}
}
class MyHomePage extends StatelessWidget{
final String title;
MyHomePage({Key key,this.title}):super(key:key);
@override
Widget build(BuildContext context) {
// TODO: implement build
return Scaffold(
appBar: AppBar(title: Text(title),),
body: Center(child: Text('$title Demo'),),
drawer: Drawer(
child: ListView(
padding: EdgeInsets.zero,
children: <Widget>[
DrawerHeader(
child: Text('$title Demo'),
decoration: BoxDecoration(
color: Colors.blue
),
),
ListTile(
title: Text("React"),
onTap: (){
Navigator.pop(context);
},
),
ListTile(
title: Text("Vue"),
onTap: (){
Navigator.pop(context);
},
)
],
),
),
);
}
}以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Android自定义ViewPagerIndicator实现炫酷导航栏指示器(ViewPager+Fragment)
这篇文章主要为大家详细介绍了Android自定义ViewPagerIndicator实现炫酷导航栏指示器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-02-02
Android实现Activity、Service与Broadcaster三大组件之间互相调用的方法详解
这篇文章主要介绍了Android实现Activity、Service与Broadcaster三大组件之间互相调用的方法,结合实例形式详细分析了Activity、Service与Broadcaster三大组件相互调用的原理,实现方法与相关注意事项,需要的朋友可以参考下2016-03-03
Android使用CircleImageView实现圆形头像的方法
圆形头像看起来非常美观,下文通过实例代码给大家介绍android中使用CircleImageView实现圆形头像的方法,一起看看吧2016-09-09
Android 使用 Scroller 实现平滑滚动功能的示例代码
这篇文章主要介绍了Android 使用 Scroller 实现平滑滚动功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-07-07
Android之线程池ThreadPoolExecutor的简介
今天小编就为大家分享一篇关于Android之线程池ThreadPoolExecutor的简介,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2019-03-03
Android中使用SeekBar拖动条实现改变图片透明度(代码实现)
这篇文章主要介绍了Android中使用SeekBar拖动条实现改变图片透明度,需要的朋友可以参考下2020-01-01


最新评论