If we are developing an App by Flutter, maybe sometimes we can build a simple sidebar to let users configure their settings.
data:image/s3,"s3://crabby-images/a5668/a5668c28a9b46788bff32b5aec5a74de4ced9f40" alt=""
Just like this.
So today I will record how to use Drawer component in Flutter to make this UI.
If you want to read some official document, you can refer:
那我今天就簡單紀錄一下該怎麼使用這樣子的側邊欄。 https://flutter.dev/docs/cookbook/design/drawer
Drawer
Building a sidebar is so easy in Flutter; We just need to set a drawer component is Scaffold.
My setting's order is build by a column layout ([Flutter] How to use Column and Row to design layout):
- DrawerHeader
- ListView
- ...
- More component you want to show
import 'package:flutter/material.dart'; import 'package:flutter/rendering.dart'; void main() => runApp(MyApp()); class MyApp extends StatelessWidget{ @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( appBar: AppBar( backgroundColor: Colors.orange, title: Text('Drawer Test'), ), drawer: Drawer( child: Column( children: <Widget>[ DrawerHeader( decoration: BoxDecoration( color: Colors.orange, ), child: ListView( children: <Widget>[ Text('Personal Information', textAlign: TextAlign.center,), ], ), ), ListTile( title: Text('Name'), leading: Icon(Icons.people), ), Divider(), ListTile( title: Text('Age'), leading: Icon(Icons.calendar_view_day), ), Divider(), ], ) ), ), ); } }
Output:
data:image/s3,"s3://crabby-images/5b823/5b823ec767287a7dc7a4fea0ec8088b2f9f04a70" alt=""
Click the left-top option icon:
data:image/s3,"s3://crabby-images/6b070/6b0705ff9c8a2eff701ecabfa0402f381662597d" alt="這張圖片的 alt 屬性值為空,它的檔案名稱為 02-2.png"
As you can see, we show a simple sidebar in our main page and do not need to navigate to any other page.
Or create a sidebar by yourself
But if you want a sidebar no need to click, you can create it by Container component. (or try mobile_sidebar package)
import 'package:flutter/material.dart'; import 'package:flutter/rendering.dart'; void main() => runApp(MyApp()); class MyApp extends StatelessWidget{ @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( appBar: AppBar( backgroundColor: Colors.orange, title: Text('Drawer Test'), ), body: sideBar(), ), ); } } class sideBar extends StatelessWidget{ @override Widget build(BuildContext context) { return Container( width: MediaQuery.of(context).size.width/5*2, color: Colors.orange, child: Column( children: <Widget>[ Text('Personal Information', textAlign: TextAlign.center, style: TextStyle(fontSize: 20, fontWeight: FontWeight.bold, color: Colors.white)), Divider(), ListTile( title: Text('Name'), leading: Icon(Icons.people), ), Divider(), ListTile( title: Text('Age'), leading: Icon(Icons.calendar_view_day), ), Divider(), ], ), ); } }
Output:
data:image/s3,"s3://crabby-images/e0e32/e0e3208b8f6ba85cd664a297eb3c633f9574b584" alt=""
It should be noted that the interface may conflict when the phone is rotated.