我希望能够以编程方式更改导航栏选项卡。我在Page1中有一个导航到Page2的按钮。执行此操作时,导航栏消失了,因为我没有使用导航栏选择page2。
我沿着Navigationbar.dart,page1.dart,page2.dart,page3.dart行有4个dart文件
导航页面是带有子项的应用程序的主页:
final List<Widget> _children = [ Page1(), Page2(), Page3(), ]; return Scaffold( backgroundColor: Colors.black, body: _children[_selectedPage], bottomNavigationBar: _bottomNavigationBar(context), resizeToAvoidBottomPadding: true, );
您必须像这样更改TabControlller
1 *创建TabController实例
TabController _tabController;
initState方法中的2 *使用此
@override void initState() { super.initState(); _tabController = TabController(vsync: this, length: 3); }
3 *将Mixin添加到_HomeState
class _HomeState extends State<Home> with SingleTickerProviderStateMixin {....}
4 *将TabController分配给TabBar
TabBar( controller: _tabController, tabs: _yourTabsHere, ),
5 *将控制器传递给您的页面
TabBarView( controller: _tabController, children:<Widget> [ Page1(tabController:_tabController), Page2(tabController:_tabController), Page3(tabController:_tabController), ];
6 *从Page1调用tabController.animateTo()
class Page1 extends StatefulWidget { final TabController tabController Page1({this.tabController}); ....} class _Page1State extends State<Page1>{ .... onButtonClick(){ widget._tabController.animateTo(index); //index is the index of the page your are intending to (open. 1 for page2) } }
希望能帮助到你