12-Flutter移动电商实战-首页导航区域编写

12-Flutter移动电商实战-首页导航区域编写

1、导航单元素的编写

从外部看,导航是一个GridView部件,但是每一个导航又是一个上下关系的Column。小伙伴们都知道Flutter有多层嵌套的问题,如果我们都写在一个组件里,那势必造成嵌套严重,不利于项目以后的维护工作。所以我们单独把每一个自元素导航拿出来,一个方法,返回一个组件。

代码如下:详细的解释可以观看视频。

class TopNavigator extends StatelessWidget {final List navigatorList;TopNavigator({Key key, this.navigatorList}) : super(key: key);Widget _gridViewItemUI(BuildContext context,item){return InkWell(onTap: (){print('点击了导航');},child: Column(children: <Widget>[Image.network(item['image'],width:ScreenUtil().setWidth(95)),Text(item['mallCategoryName'])],),);}
}

2、GridView制作导航

这个制作我们还是在外层嵌套一个Container组件,然后直接使用GridView。代码如下:

@overrideWidget build(BuildContext context) {return Container(height: ScreenUtil().setHeight(320),padding:EdgeInsets.all(3.0),child: GridView.count(crossAxisCount: 5,padding: EdgeInsets.all(4.0),children: navigatorList.map((item){return _gridViewItemUI(context, item);}).toList(),),);}

需要注意的是children属性,我们使用了map循环,然后再使用toList()进行转换。

3、数据处理和Bug解决

在HomePage的build方法里声明一个List变量,然后把数据进行List转换。再调用TopNavigator自定义组件。

 List<Map> navigatorList =(data['data']['category'] as List).cast(); //类别列表TopNavigator(navigatorList:navigatorList),  //导航组件

这时候进行预览界面,你会发现界面有些问题,就是多了一个类别,并不是我们想要的10个列表,其实如果正常,这应该是后端给数据的一个Bug。但是我们是没办法去找后端麻烦的,所以只能自己想办法解决这个问题。

解决的办法就是把List进行截取,方法如下。

if(navigatorList.length>10){navigatorList.removeRange(10, navigatorList.length);
}

全部完整代码:

import 'dart:convert';import 'package:flutter/material.dart';
import '../service/service_method.dart';
import 'package:flutter_swiper/flutter_swiper.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';class HomePage extends StatefulWidget {_HomePageState createState() => _HomePageState();}class _HomePageState extends State<HomePage{String homePageContent='正在获取数据';@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text('百姓生活+'),),body:FutureBuilder(future: getHomePageContent(),builder: (context,snapshot){if(snapshot.hasData){var data = json.decode(snapshot.data.toString());List<Map> swiper = (data['data']['slides'as List).cast();List<Map> navigatorList = (data['data']['category'as List).cast(); 类别列表return Column(children: <Widget>[SwiperDiy(swiperDataList: swiper,),TopNavigator(navigatorList: navigatorList,)],);}else{return Center(child: Text("加载中"),);}},));}
}轮播组件
class SwiperDiy extends StatelessWidget {final List swiperDataList;SwiperDiy({Key key,this.swiperDataList}):super(key:key);@overrideWidget build(BuildContext context) {ScreenUtil.instance = ScreenUtil(width: 750,height: 1334)..init(context);return Container(height: ScreenUtil().setHeight(333),width: ScreenUtil().setWidth(750),child: Swiper(itemCount: swiperDataList.length,itemBuilder: (BuildContext context,int index){return Image.network("${swiperDataList[index]['image']}",fit:BoxFit.fill);},pagination: SwiperPagination(),autoplay: true,),);}
}class TopNavigator extends StatelessWidget {final List navigatorList;TopNavigator({this.navigatorList});Widget _gradViewItemUi(BuildContext context,item){return InkWell(onTap: (){print("点击了导航");},child: Column(children: <Widget>[Image.network(item['image'],width: ScreenUtil().setWidth(95),),Text(item['mallCategoryName'])],),);}@overrideWidget build(BuildContext context) {if(navigatorList.length>10){navigatorList.removeRange(10, navigatorList.length);}return Container(height: ScreenUtil().setHeight(320),padding: EdgeInsets.all(3.0),child: GridView.count(crossAxisCount: 5,padding: EdgeInsets.all(4.0),children: navigatorList.map((item){return _gradViewItemUi(context, item);}).toList(),),);}
}

效果如下图所示:

posted @ 2019-06-15 22:48 niceyoo 阅读(...) 评论(...) 编辑 收藏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/414367.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Day3_操作记录

python基础&#xff1a; 回顾 1. 条件判断 if &#xff1a; x else&#xff1a; xx 循环 while for for i in range(5): 2. 数据类型&#xff1a; int 类型 float 小数类…

Android 全局悬浮按钮,悬浮按钮点击事件

实现效果&#xff1a; 实现方法&#xff1a; 在自定义baseActivity里面添加viwe即可。在子activity里刷新悬浮View即可 public abstract class BaseActivity extends BaseCommonActivity {LinearLayout saoli,ewmli;ImageView imageView;private QrCodeDialog mMQrCodeDialog;p…

13-Flutter移动电商实战-ADBanner组件的编写

1、AdBanner组件的编写 我们还是把这部分单独出来&#xff0c;需要说明的是&#xff0c;这个Class你也是可以完全独立成一个dart文件的。代码如下&#xff1a; 广告图片class AdBanner extends StatelessWidget { final String advertesPicture; AdBanner({Key key, this.adv…

android远程调试工具,android投屏工具

远程调试工具 说明&#xff1a;远程对方电脑需下载安装两个软件&#xff1a;Android studio 和向日葵 android投屏工具 说明&#xff1a;涉及硬件开发时&#xff0c;有的硬件没有安卓屏&#xff0c;可以使用 两个工具exe文件下载连接&#xff1a; https://download.csdn.net/…

14-Flutter移动电商实战-ADBanner组件的编写

拨打电话的功能在app里也很常见&#xff0c;比如一般的外卖app都会有这个才做。其实Flutter本身是没给我们提供拨打电话的能力的&#xff0c;那我们如何来拨打电话那? 1、编写店长电话模块 这个小伙伴们一定轻车熟路了&#xff0c;我也就不再多介绍吧。直接看代码&#xff0c;…

Android 捕获异常,上报异常日志,捕获奔溃日志,bugly使用实例

1、登录腾讯bugly平台创建应用 腾讯Bugly - 一种愉悦的开发方式 _android anr_android anr分析_iOS崩溃日志分析平台 2、1加载依赖 /*崩溃处理 */ implementation com.tonystark.android:defense_crash:2.0.0 //bugly implementation com.tencent.bugly:crashreport_upgrade:1.…

Android 获取天气数据

/** * 天气API * param cityname * return */ private String getUrl(String cityname){ return "http://wthrcdn.etouch.cn/weather_mini?city"cityname; } 传入城市&#xff0c;即可返回天气数据

windows下dos窗口实现持续ping显示时间保存至日志

效果图 右击新建 ping.bat 文件&#xff08;ping为文件名称&#xff0c;随便起&#xff09;&#xff0c;内容如下&#xff1a; cscript ping.vbs 127.0.0.1 -t >log.txt127.0.0.1 修改为你自己的ip地址&#xff0c;log 为记录日志的文件名 右击新建 ping.vbs 文件&#x…

AndroidStudio中Flutter打包APK

1、生成签名文件 在打包之前我们需要一个签名文件&#xff0c;证明文件的唯一性。 keytool -genkey -v -keystore F:\APP\sign.jks -keyalg RSA -keysize 2048 -validity 10000 -alias signF:\APP\sign.jks为签名问价存放目录&#xff0c;sign 为密钥名。 后面都有用&#x…

Codeforces #471

C(分段) 题意&#xff1a; 分析&#xff1a; 我们分别考虑p2和p>3的情况  当p2的时候&#xff0c;个数明显是[L,R]内完全平方数的个数 当p>3的时候&#xff0c;我们注意到这样的数字个数是1e6级别的&#xff0c;且a最多也不超过1e6 我们可以对于每个a去枚举对应的p&…

Thinkpad Access Connections实现快速的在各种网络间进行切换

Thinkpad Access Connections快速的在各种网络间进行切换因为工作的原因要经常在多个无线或有线之间切换&#xff0c;每次要切换到不同的固定IP地址的网络更是一种折磨&#xff0c;换一次就要从新输入一次IP地址&#xff0c;Windows下有没有像Linux的NetworkManage那样的网络管…

15-Flutter移动电商实战-商品推荐区域制作

1、推荐商品类的编写 这个类接收一个List参数&#xff0c;就是推荐商品的列表&#xff0c;这个列表是可以左右滚动的。 /*商品推荐*/class Recommend extends StatelessWidget { final List recommendList; Recommend({Key key, this.recommendList}) : super(key: key);} 2…

gradle sync failed——Android studio 突然就无法自动下载gradle了

不知道按到了什么鬼&#xff0c;或者新安装了Android studio 无法使用 正常gradle文件位置是不需要修改的 android studio会自动配置 出现这个错误&#xff0c;就需要收到补全gradle文件路径配置即可 1、查看项目gradle版本 2、补全即可——加上后面这段对应项目里的版本的文件…