#flutter #dart #tabs #widget
#трепетание #dart #вкладки #виджет
Вопрос:
В настоящее время у меня проблема с отображением разных виджетов для каждой вкладки, которую я выбираю.
Могу ли я каким-либо образом изменить текст или что-либо еще, когда я нажимаю на другую панель вкладок?
Я попытался использовать tabNames [index] и index внутри переключателя, и я создал разные регистры для каждой страницы, но это не работает. У меня есть несколько виджетов, которые я хочу отображать на каждой вкладке, в зависимости от того, на какой вкладке я нажимаю.
import 'package:flutter/material.dart';
void main() {
runApp(new MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new MaterialApp(
title: 'Navigation Example',
home: new MyHomePage(),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key}) : super(key: key);
@override
_MyHomePageState createState() => new _MyHomePageState();
}
const List<String> tabNames = const<String>[
'foo', 'bar', 'baz', 'quox', 'quuz', 'corge', 'grault', 'garply', 'waldo'
];
class _MyHomePageState extends State<MyHomePage> {
int _screen = 0;
@override
Widget build(BuildContext context) {
return new DefaultTabController(
length: tabNames.length,
child: new Scaffold(
appBar: new AppBar(
title: new Text('Navigation example'),
),
body: new TabBarView(
children: new List<Widget>.generate(tabNames.length, (int index) {
switch (_screen) {
case 0: return new Center(
child: new Text('First screen, ${tabNames[index]}'),
);
case 1: return new Center(
child: new Text('Second screen'),
);
}
}),
),
bottomNavigationBar: new Column(
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.stretch,
children: [
new AnimatedCrossFade(
firstChild: new Material(
color: Theme
.of(context)
.primaryColor,
child: new TabBar(
isScrollable: true,
tabs: new List.generate(tabNames.length, (index) {
return new Tab(text: tabNames[index].toUpperCase());
}),
),
),
secondChild: new Container(),
crossFadeState: _screen == 0
? CrossFadeState.showFirst
: CrossFadeState.showSecond,
duration: const Duration(milliseconds: 300),
),
new BottomNavigationBar(
currentIndex: _screen,
onTap: (int index) {
setState(() {
_screen = index;
});
},
items: [
new BottomNavigationBarItem(
icon: new Icon(Icons.airplanemode_active),
title: new Text('Airplane'),
),
new BottomNavigationBarItem(
icon: new Icon(Icons.motorcycle),
title: new Text('Motorcycle'),
),
],
),
],
),
),
);
}
}
Ответ №1:
Я не думаю, что способ передачи списка виджетов в TabBarView является подходящим. Не используйте List.generate: вместо этого попробуйте обернуть свои виджеты следующим образом:
body: TabBarView(
children: [
Center(child: Text('First screen')),
Center(child: Text('Second screen')),
]
),
Контроллер вкладок динамически обрабатывает смену страниц без необходимости устанавливать переключатель для выбора экрана.