Как я могу использовать меню флаттер-ящика при маршрутизации страниц?
Я новичок в флаттере и кодировании.
Что я хочу сделать:
- чтобы добавить меню ящика в main.dart, он вернет Scaffold для всех страниц в меню.
- на каждой странице я хочу использовать разные скаффолды. (панель приложений и тело)
я создал страницы, маршруты, ящик; но я не мог добавить ящик на страницы, а также в Builder(main.dart), я думаю, что у меня есть некоторые ошибки.
main.dart выглядит так:
import 'package:flutter/material.dart';
import 'package:letter_app/screens/user/postbox.dart';
import 'package:letter_app/screens/user/unread.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatefulWidget {
@override
State<StatefulWidget> createState() {
return MyAppState();
}
}
class MyAppState extends State<MyApp> {
int selectedMenuItem = 0;
final pageOptions = [
PostBox(),
Unread(),
];
Widget buildDrawer(BuildContext context) {
return Drawer(
child: ListView(
children: <Widget>[
DrawerHeader(
child: Text('Drawer Header'),
decoration: BoxDecoration(),
),
ListTile(
title: Text('Unread'),
onTap: () {
Navigator.of(context)
.push(MaterialPageRoute(builder: (context) => new Unread()));
Navigator.pop(context);
},
),
ListTile(
title: Text('Post Box'),
onTap: () {
Navigator.of(context)
.push(MaterialPageRoute(builder: (context) => new PostBox()));
Navigator.pop(context);
},
),
],
),
);
}
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'New App',
theme: ThemeData.dark(),
routes: <String, WidgetBuilder>{
'/screens/user/unread.dart': (BuildContext context) => Unread(),
'/screens/user/postbox.dart': (BuildContext context) => PostBox(),
},
home: Builder(
builder: (context) => Scaffold(
drawer: buildDrawer(context),
body: Container(child: pageOptions[selectedMenuItem]),
),
),
);
}
}
unread.dart выглядит так:
import 'package:flutter/material.dart';
class Unread extends StatefulWidget {
@override
_UnreadState createState() => _UnreadState();
}
class _UnreadState extends State<Unread> {
@override
Widget build(BuildContext context) {
return Scaffold(
drawer: ,
appBar: AppBar(
title: Text('Welcome to Flutter'),
),
body: Center(
child: Text('Unread'),
),
);
}
}
1 ответ
Решение
Просто определите виджет buildDrawer в отдельном файле dart, импортируйте файл. Затем просто назначьте его каждому эшафоту.