Flutter实现常用底部栏

文章介绍

之前写过一篇Flutter介绍的文章,然后因为一些其他事情停了好久没写了。这人一懒下来就懒成习惯了哈哈。这次的文章主要是介绍用Flutter实现一个app常用的底部tab栏,类似于安卓里面的BottomNaivigationView。有三个页面可以点击切换这样子。

项目结构

项目结构

FirstTab里面的代码:

import 'package:flutter/material.dart';

class FirstTab extends StatefulWidget {
  @override
  _FirstTabState createState() => _FirstTabState();
}

class _FirstTabState extends State<FirstTab> {
  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      appBar: new AppBar(
        title: new Text('第一个界面'),
      ),
      body: new Center(
        child: new Text('first'),
      ),
    );
  }
}

就是一个简单的界面,一个标题栏文本,和一个居中的文本。第二个和第三个界面也都是一样类似的,文本不同而已。这里教大家一个小技巧,在AndroidStudio里面创建Widget的快捷键。

stful ===> 创建一个StatefulWidget,并且会自动生成State,很省事
stless ===> 创建一个StatelessWidget

Widget生命周期

在把这三个界面整合到一起之前,我想先插入一点很重要的知识。在Flutter里面万物皆是Widget,所以我想先介绍一下Widget的生命周期。但是说Widget的生命周期这个说法其实是不准确的。
因为Widget分为StatefulWidget和StatelessWidget,可变的是StatefulWidget,它的可变又是通过修改State来完成的,等下在代码里面可以看到有@override标识的生命周期方法其实是在继承于State的状态类里面写的。所以说成是State的生命周期更加准确一点。

方法名称 状态
initState 插入渲染树时调用,只调用一次
didChangeDependencies state依赖的对象发生变化时调用
didUpdateWidget 组件状态改变时候调用,可能会调用多次
build 构建Widget时调用
deactivate 当移除渲染树的时候调用
dispose 组件即将销毁时调用

完整的生命如图所有的方法和分阶段执行的图解,很详细了。图片是从闲鱼技术那里copy来的。推荐大家都关注一下闲鱼技术,他们确实在Flutter这一块有很多自己的实践文章


生命周期

主入口

现在我们把三个页面放到main.dart里面,做出一个类似BottomNaivigationView的效果。
首先在main.dart文件里面导入之前我们写好的三个tab页

import './pages/FirstTab.dart';
import './pages/SecondTab.dart';
import './pages/ThirdTab.dart';

我这里因为是已经写完了,就是使用过这三个了,字体不会是灰色带波浪线的。所以大家碰到灰色带波浪线的话也不要慌张,写完就好了。
main.dart完整代码:

import 'package:flutter/material.dart';
import './pages/FirstTab.dart';
import './pages/SecondTab.dart';
import './pages/ThirdTab.dart';

void main(){
  runApp(
    new MaterialApp(
      title:'tabdemo',
      home:new HomePage()
    )
  );
}

class HomePage extends StatefulWidget {
  @override
  _HomePageState createState() =>new _HomePageState();
}

class _HomePageState extends State<HomePage> with SingleTickerProviderStateMixin{
  
  //Tab页的控制器,可以用来定义Tab标签和内容页的坐标
  TabController tabcontroller;
  
  
  //生命周期方法插入渲染树时调用,只调用一次
  @override
  void initState() {
    super.initState();
    tabcontroller = new TabController(
      length: 3,   //Tab页的个数
      vsync: this //动画效果的异步处理,默认格式
    );
  }
  
  //生命周期方法构建Widget时调用
  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      body: new TabBarView(
        controller: tabcontroller,
        children: <Widget>[
          //创建之前写好的三个页面,万物皆是Widget
          new FirstTab(),
          new SecondTab(),
          new ThirdTab(),
        ],
      ),
      bottomNavigationBar: new Material(
        //底部栏整体的颜色
        color: Colors.blueAccent,
        child: new TabBar(
          controller: tabcontroller,
          tabs: <Tab>[
            new Tab(text: "第一个",icon: new Icon(Icons.android)),
            new Tab(text: "第二个",icon: new Icon(Icons.home)),
            new Tab(text: "第三个",icon: new Icon(Icons.accessibility)),
          ],
          //tab被选中时的颜色,设置之后选中的时候,icon和text都会变色
          labelColor: Colors.amber,
          //tab未被选中时的颜色,设置之后选中的时候,icon和text都会变色
          unselectedLabelColor: Colors.black,
        ),
      )
    );
  }
  
  //组件即将销毁时调用
  @override
  void dispose() {
    //释放内存,节省开销
    tabcontroller.dispose();
    super.dispose();
  }
}

1.首先main方法是主入口。title里面的标题就是app在后台时显示的名字。
2.HomePage是一个有状态的组件,通过修改_HomePageState 来修改他显示内容
3._HomePageState 里面有三个方法initState,build,dispose。这三个都是生命周期方法,上面表格里面有详细描述,在这里是按照我代码里面的顺序执行的。
4.TabController相当于是tabbar的控制器,在build方法里面创建控件的时候作为参数传入
5.build方法里面先是创建了一个Scaffold,然后里面放入了控件,也就是界面显示出来的东西,类似于安卓里面的view。控件的具体用法可参考 Widget目录
6.最后在dispose组件销毁的时候销毁掉tabcontroller

运行效果

最终效果

其实实现的也比较简单,就是三个可以切换的页面,既可以点击切换,又可以滑动切换。

补充说明

我的代码里面有很多new关键字,其实在Dart2里面这些new是可以省略掉的,但是因为我写Java写习惯了,为了便于大家阅读,我还是加了new的。
然后其实我现在也只是一个小菜鸡,一些复杂的界面自己现在也实现不了,还在学习之中。后期抽空会把这三个子界面完善出来,尽量实现一些常用的东西,比如列表,界面跳转,手势,动画之类的。暂时的想法是这样。谢谢阅读,大家周末愉快~

代码地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354

推荐阅读更多精彩内容