Как перейти на новый экран по клику на иконку BottomAppBar?
Я хочу перейти к новому экрану при нажатии значков BottomAppBar, но я получаю сообщение об ошибке: в инициализаторах могут быть доступны только статические элементы
final makeBottom = Container(
height: 45.0,
child: BottomAppBar(
color: Colors.white,
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
IconButton(
icon: Icon(Icons.home, color: Color.fromARGB(255, 30, 110, 160)),
onPressed: navigateToPage,//only static members can be accessed in initializers
),
IconButton(
icon: Icon(Icons.search, color: Color.fromARGB(255, 30, 110, 160)),
onPressed: () {},
),
IconButton(
icon: Icon(Icons.star, color: Color.fromARGB(255, 30, 110, 160)),
onPressed: () {},
),
IconButton(
icon: Icon(Icons.favorite_border,
color: Color.fromARGB(255, 30, 110, 160)),
onPressed: () {},
),
IconButton(
icon: Icon(Icons.account_circle,
color: Color.fromARGB(255, 30, 110, 160)),
onPressed: () {},
),
],
),
),
);
метод navigateToPage
void navigateToPage() async {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => Userqst(
user: widget.user,
),
fullscreenDialog: true));
}
4 ответа
Попробуйте это ниже код..
return Scaffold{
bottomNavigationBar : bottomNav() // call the Widget
}
Widget bottomNav(){
return new Container (
height :45.0,
//Copy the bottomAppBar code
);
}
Я думаю, что вы пытаетесь построить этот виджет из контекста "Сборка виджета (контекст BuildContext)", поэтому у вас возникла эта проблема.
Я думал о 2 решениях для этого.
Сначала вы помещаете свой код в основную функцию "Сборка виджета (контекст BuildContext)" и вызываете виджет везде, где хотите.
@override
Widget build(BuildContext context){
//here you put your "final makeBottom" code;
return Scaffold(//and somewhere around there you place your "makeBottom" Widget);
}
Во-вторых, оберните весь ваш код как функцию, которая вернет этот контейнер (), а затем вызовите его в функцию "сборки".
Widget makeBottom(BuildContext context){
return //your Container();
}
Проблема может быть в том, что у вашего метода нет контекста
IconButton(
icon: Icon(Icons.home, color: Color.fromARGB(255, 30, 110, 160)),
onPressed: (){navigateToPage(context);},//only static members can be accessed in initializers
),
И попробуйте изменить метод, как это
void navigateToPage(BuildContext context) async {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => Userqst(
user: widget.user,
),
fullscreenDialog: true));
}
Ниже код может помочь вам -
class Home extends StatefulWidget {
@override
State<StatefulWidget> createState() {
return _HomeState();
}
}
class _HomeState extends State<Home> {
int _currentIndex = 0;
final List<Widget> _children = [
HomeListView(),
MyGridView()
];
var _title = 'Home';
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
backgroundColor: Color.fromRGBO(41, 167, 77, 50),
title: Text(_title, textAlign: TextAlign.center),
),
body: _children[_currentIndex],
bottomNavigationBar: BottomNavigationBar(
onTap: onTabTapped,
selectedItemColor: Color.fromRGBO(33, 137, 38, 60),
type: BottomNavigationBarType.fixed,
backgroundColor: Color.fromRGBO(252, 207, 3, 60),
currentIndex: _currentIndex,
// this will be set when a new tab is tapped
items: [
BottomNavigationBarItem(
icon: new Icon(Icons.home),
title: new Text('Home'),
),
BottomNavigationBarItem(
icon: new Icon(Icons.mail),
title: new Text('My Venue'),
)
],
),
);
}
void onTabTapped(int index) {
setState(() {
_currentIndex = index;
switch (index) {
case 0:
_title = 'Home';
break;
case 1:
_title = 'My Venue';
break;
}
});
}
}