Вы можете создать поле функции в вашем SideDrawer , которое принимает index в качестве параметра.
Вызовите функцию, передав соответствующий параметр в onTap каждого ListTile .
В вашем MyApp создайте переменную с начальным значением 0, затем при установке SideDrawer добавьте onTap атрибут затем изменить значение в setState
Вот так
class MyApp2 extends StatefulWidget {
@override
MyApp2State createState() => MyApp2State();
}
class MyApp2State extends State<MyApp2> {
var widgetIndex = 0;
@override
Widget build(BuildContext context)
{
return Scaffold(
appBar: AppBar(
title: Text("Home"),
),
body: SafeArea(
child: Container(
child: IndexedStack(
index: widgetIndex,
children: <Widget>[
Text("djdhjhd"),
Text("nonono")
],
),
),
),
drawer: SideDrawer(
onTap: (index){
setState(() {
widgetIndex = index;
});
},
),
);
}
}
class SideDrawer extends StatefulWidget {
final Function(int index) onTap;
SideDrawer({this.onTap});
@override
SideDrawerState createState() => SideDrawerState();
}
class SideDrawerState extends State<SideDrawer> {
@override
Widget build(BuildContext context) {
return Drawer(
child: Column(
children: <Widget>[
ListTile(
contentPadding: EdgeInsets.only(top: 50),
title: Text('1'),
onTap: () async {
widget.onTap(0);
Navigator.of(context).pop();
},
),
ListTile(
title: Text('2'),
onTap: (){
widget.onTap(1);
Navigator.of(context).pop();
},
),
],
),
);
}
}
Вывод:
data:image/s3,"s3://crabby-images/1d38a/1d38ad08fe51a6bcb652f0e84a2e5a987833fc42" alt="enter image description here"
Надеюсь, это поможет вам.