我尝试为我的应用程序实现BottomNavigationBar。但是我不起作用。
这是我的代码:
// Vertretungsplan Montag
class VPMontag extends StatelessWidget {
String url;
VPMontag(this.url);
最终完成者_controller = Completer();
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('Vertretungsplan Montag'),
),
body: Builder(builder: (BuildContext context) {
return WebView(
initialUrl: url,
javascriptMode: JavascriptMode.unrestricted,
onWebViewCreated: (WebViewController webViewController) {
_controller.complete(webViewController);
},
navigationDelegate: (NavigationRequest request) {
if (request.url.startsWith('https://www.youtube.com/')) {
print('blocking navigation to $request}');
return NavigationDecision.prevent;
}
print('allowing navigation to $request');
return NavigationDecision.navigate;
},
onPageStarted: (String url) {
print('Page started loading: $url');
},
onPageFinished: (String url) {
print('Page finished loading: $url');
},
gestureNavigationEnabled: true,
);
}));
}
}
...
vpmontag() {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => VPMontag('myurl')));
}
int _selectedIndex = 0;
static TextStyle optionStyle = TextStyle(fontSize: 30, fontWeight: FontWeight.bold);
static List<Widget> _widgetOptions = <Widget>[
Text(
'Index 0: Home',
style: optionStyle,
),
Center(
child: Container(
child: Column(
children: <Widget>[
RaisedButton(
onPressed: vpmontag,
child: Text('Montag'),
),
),
],
),
),
),
Text(
'Index 2: School',
style: optionStyle,
),
];
void _onItemTapped(int index) {
setState(() {
_selectedIndex = index;
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('VP App'),
),
body: Center(
child: _widgetOptions.elementAt(_selectedIndex),
),
bottomNavigationBar: BottomNavigationBar(
items: const <BottomNavigationBarItem>[
BottomNavigationBarItem(
icon: Icon(Icons.home),
title: Text('Startseite'),
),
BottomNavigationBarItem(
icon: Icon(Icons.view_headline),
title: Text('Vertretungspläne'),
),
BottomNavigationBarItem(
icon: Icon(Icons.calendar_today),
title: Text('Stundenpläne'),
),
],
currentIndex: _selectedIndex,
selectedItemColor: Colors.blue[800],
onTap: _onItemTapped,
),
);
}
}
但是我得到这个错误:
Compiler message:
lib/main.dart:314:26: Error: Can't access 'this' in a field initializer to read 'vpmontag'.
onPressed: vpmontag,
^^^^^^^^
我有五次参加“ VP Montag”课,但有其他名字。
我该如何解决?我是否必须在任何地方添加“ this.vpmontag”?
非常感谢您的帮助。
答案 0 :(得分:2)
只需尝试在State类的 initState()方法中初始化 _widgetOptions 变量
List<Widget> _widgetOptions = [];
@override
void initState() {
_widgetOptions = <Widget>[
Text(
'Index 0: Home',
style: optionStyle,
),
Center(
child: Container(
child: Column(
children: <Widget>[
RaisedButton(
onPressed: vpmontag,
child: Text('Montag'),
),
],
),
),
),
Text(
'Index 2: School',
style: optionStyle,
),
];
super.initState();
}