flutter TabBar+PageView页卡切换页面

TabController _firstPageTabController;
PageController _pageController;

class _FirstPageNewState extends State<FirstPageNew> with SingleTickerProviderStateMixin{

void initState() {
    // TODO: implement initState
    super.initState();
    _firstPageTabController = TabController(initialIndex: 0);
    _pageController = PageController(initialPage: 0);
	_firstPageTabController.addListener(_onTabChanged);
    }

 Tab 改变时,切换 PageView
_onTabChanged() {
    if (_firstPageTabController.indexIsChanging) return;
    _pageController.jumpToPage(_firstPageTabController.index);
  }
  
 // PageView 改变时,更新 TabBar
 _onPageChanged(int index) {
    if (_firstPageTabController.index != index) {
      _firstPageTabController.animateTo(index);
    }
  }

 
  void dispose() {
    // TODO: implement dispose
    _pageController.dispose();
    _firstPageTabController.dispose();
    super.dispose();
  }


  Widget build(BuildContext context) {
    // TODO: implement build
    return DefaultTabController(
      length: pagesList.length,
      initialIndex: 0,
      child: Scaffold(
          appBar: AppBar(),
          body: _body()
      )
    );
  }

_body(){
    return PageView.builder(
        controller: _pageController,
        pageSnapping: true,
         onPageChanged: _onPageChanged,
        itemCount: pagesList.length,
        itemBuilder: (_, index){
          return PageItemView(index,key: ValueKey(index));
        });
  }

}  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值