12.首页_GridView类别导航制作

 首页导航区的制作

 Flutter实战视频-移动电商-12.首页_GridView类别导航制作

外面用一个gridview来写。里面单独提出来

 

新建导航组件

还是在home_page.dart里面写代码

新建一个静态的组件:

快捷键写组件的时候选择哪个stlessW的,这样把构造函数也帮你初始化好了。

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

定义一个内部的方法 ,返回的是一个column,内部方法名开头用下划线开头。

定义方法 _gridViewItemUI接收两个参数一个是上下文对象,一个item相当于我们每一个导航项

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

我们导航项点一下肯定要有页面的变化,或者是路由的跳转。这个时候就是使用使用我们的小部件InkWell。外层用InkWell主要是它可以接受一个点击事件。

当前我们只输出一句话就可以了。然后里面的Child我们用Column就可以了

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

把我们的ScreenUtil初始化放在,main.dart中第一个调用的页面

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

注意引入:import 'package:flutter_screenutil/flutter_screenutil.dart';

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

这样就相当于我们进行了全局设置。

这样我们的Column就写完了。

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

外层套一个Container方便扩展

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

因为我们上面已经接收一个list了。这里children的地方我们直接用navigatorList进行遍历

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

map里面接收一个回调,map后就不是list对象了。因此最后需要加上toList()

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

return直接调用我们写的内部方法就可以了。

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

然后在FutureBuilder里面调用我们写的TopNavigator组件

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

预览效果:

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

往下滚动 发现最下面多了一个

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

这个是后台接口的锅,按说应该是10个的,所以只能从前端想一些办法来处理了。

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

最终代码

 

index_page.dart

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

 

Flutter实战视频-移动电商-12.首页_GridView类别导航制作

import 'package:flutter/material.dart';
import 'package:flutter/cupertino.dart';
import 'home_page.dart';
import 'category_page.dart';
import 'cart_page.dart';
import 'member_page.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';

class IndexPage extends StatefulWidget {
  @override
  _IndexPageState createState() => _IndexPageState();
}

class _IndexPageState extends State<IndexPage> {
  final List<BottomNavigationBarItem> bottomTabs=[
    BottomNavigationBarItem(
      icon:Icon(CupertinoIcons.home),//这里使用IOS风格的
      title: Text('首页')
    ),
    BottomNavigationBarItem(
      icon:Icon(CupertinoIcons.search),
      title: Text('分类')
    ),
    BottomNavigationBarItem(
      icon:Icon(CupertinoIcons.shopping_cart),
      title: Text('购物车')
    ),
    BottomNavigationBarItem(
      icon:Icon(CupertinoIcons.profile_circled),
      title: Text('会员中心')
    ) 
  ];
  final List tabBodies=[
    HomePage(),
    CategoryPage(),
    CartPage(),
    MemberPage()
  ];

  int currentIndex=0;//当前索引
  var currentPage;
 @override
  void initState() {
    currentPage=tabBodies[currentIndex];//默认页面数组内索引值为0的页面
    super.initState();
  }


  @override
  Widget build(BuildContext context) {
     ScreenUtil.instance = ScreenUtil(width: 750,height: 1334)..init(context);

    return Scaffold(
      backgroundColor: Color.fromRGBO(244, 245, 245, 1.0),//颜色固定死,比白色稍微灰一点
      bottomNavigationBar: BottomNavigationBar(
        type:BottomNavigationBarType.fixed,
        currentIndex: currentIndex,//当前索引值
        items: bottomTabs,
        onTap: (index){
          setState(() {
           currentIndex=index;
           currentPage=tabBodies[currentIndex];
          });
        },
      ),
      body: currentPage,
    );
  }
}
index_page.dart

相关文章:

  • 2021-05-29
  • 2021-12-13
  • 2022-12-23
  • 2022-01-25
  • 2021-09-26
  • 2021-06-22
  • 2022-02-26
  • 2021-05-31
猜你喜欢
  • 2022-12-23
  • 2021-11-15
  • 2021-08-18
  • 2021-09-04
  • 2021-08-14
  • 2021-11-14
  • 2022-02-10
相关资源
相似解决方案