20Flutter通过TabController定义顶部tab切换,介绍生命周期函数

基本使用:

import 'package:flutter/material.dart';

class TabBarControllerPage extends StatefulWidget {
  TabBarControllerPage({Key key}) : super(key: key);

  _TabBarControllerPageState createState() => _TabBarControllerPageState();
}

class _TabBarControllerPageState extends State<TabBarControllerPage> with SingleTickerProviderStateMixin{
  TabController _tabController;
  @override
  void dispose(){ //生命周期函数:
  super.dispose();
  _tabController.dispose();
  }
  @override
  void initState(){  //生命周期函数:
    super.initState();
    _tabController=new TabController(
      vsync: this,
      length: 2
    );
    _tabController.addListener((){
      print(_tabController.index);
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('TabBarControllerPage'),
        bottom: TabBar(
          controller:this._tabController,
          tabs: <Widget>[
            Tab(text: '热销'),
            Tab(text: '推荐')
          ],
        ),
      ),
      body: TabBarView(
        controller: this._tabController,
        children: <Widget>[
          Center(child: Text('热销')),
          Center(child: Text('推荐'))
        ],
      )

    );
  }
}

 

posted @ 2019-09-11 18:29  生如逆旅,一苇以航  阅读(2334)  评论(0编辑  收藏  举报