当前位置: 首页 > news >正文

Flutter系列教程之(6)——Tab导航与ListView使用

目录

Tab导航

ListView的使用


Tab导航

效果图:

与原生的Android不同,flutter中使用Tab的步骤还算简单,不用写Adapter

return DefaultTabController(
  //必传参数1
  length: 2,
  child: Scaffold(
	appBar: AppBar(
	  title:
	  Text('tab演示', style: TextStyle(color: Colors.white, fontSize: 18)),
	  centerTitle: true,
	  //必传参数2
	  bottom: TabBar(tabs: [
		Tab(
		  text: "标签1",
		),
		Tab(
		  text: "标签2",
		),
	  ],indicatorColor: Colors.white,labelStyle: TextStyle(fontSize: 16),),
	),
	//必传参数3
	body: TabBarView(children: [
	  TabContentPage("标签1"),
	  TabContentPage("标签2"),
	]),
  ),
);

当然,你可以根据自己需求封装个方法,必传的参数由length,TabBar和TabBarView

length表示有几个标签页,TabBar则表示上头的选项卡,你可以增加相关的参数来修改选项卡的样式,TabBarView则是选项卡对应的内容

PS:Tab这个Widget有个icon的参数,通过这个属性我们可以设置图标

TabBar这个Widget中,也是有多个参数,便于我们设置选项卡下方的横线指示器的颜色 宽度 边距,以及选项卡文字颜色等属性

ListView的使用

ListView使用的方式有多种,这里介绍一下简单的一种吧,使用ListView.builder构造ListView

ListView.builder中重要的两个参数为itemCount和itemBuilder,itemCount为子项item的数量,而itemBuilder则是子项的构造器,其类似于RecyclerViewAdapter的onBindViewHolder方法

@override
  Widget build(BuildContext context) {
    return MyMaterialPage("listview的演示",_listView());
  }
  Widget _listView(){
    //构造数据
    var nameList = ["张三"];
    for(var i=0;i<50;i++){
      nameList.add("张三$i");
    }
    return new ListView.builder(
      //listview的子项item数量
      itemCount: nameList.length,
      padding: new EdgeInsets.all(5.0),
      itemBuilder: (BuildContext context, int index) {
        //返回每个子项item的widget
        //这里我只是简单拿到数据列表中的数据,并以此为参数构造成了显示姓名的Widget
        return _listItemView(nameList[index]);
      },
    );
  }
  Widget _listItemView(String name){
    return Row(
      children: [
        Center(child: Text(name),),
      ],
    );
  }

代码效果如图所示:

我写的demo中,为了方便起见,都是使用的StatelessWidget,一般来说,ListView使用的情形是根据网络请求获得数据,之后再将数据以列表的形式显示

这里简单的介绍一下吧,代码就不放出了,我们只需要让页面继承StatefulWidget,之后在请求数据之后使用setState去修改数据,从而实现页面的改变,详情请看Flutter系列教程之(4) 自定义Widget控件及相关知识

 

相关文章:

  • Lua的table类型的增删改查操作
  • http 协议和 https 协议的区别是什么?
  • 【1分钟学会万相文生视频】windows环境4080显卡部署Wan2.1-T2V-1.3B,亲手实操
  • 【STL】7.STL常用算法(1)
  • miqiu的分布式锁(二):实战——用JMeter验证JVM锁能否解决MySQL超卖问题
  • element-ui的组件使用
  • 每日一题——字母异位词分组
  • 2024 年出现的 11 大数据收集趋势
  • spring boot 连接FTP实现文件上传
  • linux中根目录满了
  • C#开发的Base64编码及解码完整源码及注意事项
  • 【含开题报告+文档+PPT+源码】基于大数据的交通流量预测系统
  • 论软件设计模式及其应用-软考
  • 【算法】797. 差分
  • C语言番外篇(4)--------->goto语句
  • 如何进行OceanBase 运维工具的部署和表性能优化
  • Linux 内核配置机制详细讲解
  • 【Jenkins】一种灵活定义多个执行label节点的jenkinsfile写法
  • 【由技及道】模块化战争与和平-论项目结构的哲学思辨【人工智智障AI2077的开发日志】
  • 【c++】【线程池】固定式线程池(FixedThreadPool)
  • 做网站用什么服务器/友情链接多久有效果
  • 附近学电脑在哪里报名/重庆seo公司
  • 怎么成立网站/黑龙江网络推广好做吗
  • 网站群如何做网站/今天刚刚发生的新闻
  • wordpress下载站插件/在线crm系统
  • 中山精品网站建设渠道/微商刚起步怎么找客源