从Flutter发布beta版本就一直在关注Flutter、很多大厂也都在使用Flutter比如字节跳动今日头条、西瓜视频、阿里爸爸的闲鱼、毒APP,包括我们公司(一个卖菜的公司)也在部分非主流程页面使用Flutter。都说Flutter极其流畅漂亮,本着再不学习就老了的心态,于是准备抽些闲暇时间来尝试下Flutter。最近小端午放假APP的几个页面也搭建的差不多了,本着人人为我、我为人人的精神决定写个blog给大家分享一下。
因为像JD这种电商APP无论是业务逻辑还是页面复杂度都是比较复杂的,一来可以体验一下Flutter在复杂页面流畅度的表现,二来也可以看下到底Flutter是否能真正投入生产环境中。
![Simulator Screen Shot - iPhone 11 Pro Max - 2020-06-26 at 17.33.25.png](https://camo.githubusercontent.com/159c8e44acea56cc6660f67797b1199df72c487d4e6dfcbcb4ece8db970602e2/68747470733a2f2f75706c6f61642d696d616765732e6a69616e7368752e696f2f75706c6f61645f696d616765732f31313238373132322d363763646330343036306233653131662e706e673f696d6167654d6f6772322f6175746f2d6f7269656e742f7374726970253743696d61676556696577322f322f772f333030)
功能 |
方案 |
搜索滚动吸顶 |
SliverAppBar + FlexibleSpaceBar |
Banner轮播 |
flutter_swiper |
货架 |
PageView+GridView |
推荐列表 |
flutter_swiper |
![image.png](https://camo.githubusercontent.com/f5e3c44c6da9ed0dbca064a890365da2e90207756de06b70433890e1cbd79b8b/68747470733a2f2f75706c6f61642d696d616765732e6a69616e7368752e696f2f75706c6f61645f696d616765732f31313238373132322d303131343664323737373661356666302e706e673f696d6167654d6f6772322f6175746f2d6f7269656e742f7374726970253743696d61676556696577322f322f772f333030)
功能 |
方案 |
banner |
flutter_swipper |
扫一扫 |
barcode_scan |
![image.png](https://camo.githubusercontent.com/a931c4a3a7edfde54511ac63e2bdf84d08515bc8380d045b867554e41f2980df/68747470733a2f2f75706c6f61642d696d616765732e6a69616e7368752e696f2f75706c6f61645f696d616765732f31313238373132322d653133663630386637633666386639332e706e673f696d6167654d6f6772322f6175746f2d6f7269656e742f7374726970253743696d61676556696577322f322f772f333030)
功能 |
方案 |
商品选择 |
|
倒计时 |
Timer.periodic |
商品数量增减 |
自定义组件 |
![image.png](https://camo.githubusercontent.com/5822b941d6eb47292e2d6449722725ccef71b389ed9fd8c9e637d72bc67e3a6a/68747470733a2f2f75706c6f61642d696d616765732e6a69616e7368752e696f2f75706c6f61645f696d616765732f31313238373132322d626531326161383631393631366562332e706e673f696d6167654d6f6772322f6175746f2d6f7269656e742f7374726970253743696d61676556696577322f322f772f333030)
功能 |
方案 |
header滚动渐变 |
监听滚动位置设置Appbar opacity |
其它 |
页面效果还原 |
I love China, love huawei
![image.png](https://camo.githubusercontent.com/f8a01da4aa5ee31c69a48cd6349b55149ec20613ecda2b1e325616b0c5b2aaa3/68747470733a2f2f75706c6f61642d696d616765732e6a69616e7368752e696f2f75706c6f61645f696d616765732f31313238373132322d303364383532363333653863653631652e706e673f696d6167654d6f6772322f6175746f2d6f7269656e742f7374726970253743696d61676556696577322f322f772f333030)
功能 |
方案 |
备注 |
header滚动渐变 |
|
无 |
商品轮播图 |
flutter_swiper |
无 |
地址选择 |
city_pickers |
无 |
规格选择 |
showCupertinoModalPopup |
无 |
商品详情图 |
webview_flutter |
TODO Android 超过5500高度会黑屏崩溃 需要等待网页加载结束获取网页高度后重新设置webview高度否则会内存溢出 |
![image.png](https://camo.githubusercontent.com/bcafdf65e026aca9749775295b462ec769c4a6df75150e8b7561a6cea830e178/68747470733a2f2f75706c6f61642d696d616765732e6a69616e7368752e696f2f75706c6f61645f696d616765732f31313238373132322d323833663831633933383033616532632e706e673f696d6167654d6f6772322f6175746f2d6f7269656e742f7374726970253743696d61676556696577322f322f772f343030)
![image.png](https://camo.githubusercontent.com/e634ab006b517560978fe690e02d4f87b3e6c49e4fa7b37a3fb34e5ba37d4e33/68747470733a2f2f75706c6f61642d696d616765732e6a69616e7368752e696f2f75706c6f61645f696d616765732f31313238373132322d653661363437366561313136366361302e706e673f696d6167654d6f6772322f6175746f2d6f7269656e742f7374726970253743696d61676556696577322f322f772f343030)
功能 |
方案 |
备注 |
登录注册 |
leancloud |
注册登录图省事,整了一个页面(点注册按钮即使用当前输入的用户名密码注册) |
账密 |
账号 admin 密码 admin |
无 |
APP端:
Server端:
⚠️⚠️⚠️ 警告:真机运行 lib/api/api.dart中的baseUrl需要修改为你的本机IP ⚠️⚠️⚠️
![image.png](https://camo.githubusercontent.com/9467f5c63a5a7d6debead23bfa897e2d8f9ff64dc61edef389fc316f60b7cffc/68747470733a2f2f75706c6f61642d696d616765732e6a69616e7368752e696f2f75706c6f61645f696d616765732f31313238373132322d663035643963336165636161313234322e706e673f696d6167654d6f6772322f6175746f2d6f7269656e742f7374726970253743696d61676556696577322f322f772f323030)
name: learn_flutter
description: A new Flutter project.
version: 1.0.0+1
environment:
sdk: ">=2.2.2 <3.0.0"
dependencies:
flutter:
sdk: flutter
cupertino_icons: ^0.1.2
# 轮播插件
flutter_swiper: ^1.1.6
# toast
fluttertoast: ^4.0.1
# 网络请求
dio: ^3.0.8
# webview
# flutter_webview_plugin: ^0.3.5
# webview
webview_flutter: ^0.3.19
json_annotation: ^3.0.0
# 城市选择器
city_pickers: ^0.1.30
# 扫描插件
barcode_scan: ^2.0.1
# Leancloud
leancloud_storage: ^0.2.3
# 官方缓存插件
shared_preferences: ^0.5.6
# provide
provide: ^1.0.2
dev_dependencies:
flutter_test:
sdk: flutter
# json generator
build_runner: ^1.0.0
json_serializable: ^3.3.0
uses-material-design: true
assets:
- lib/assets/json/movie.json
fonts:
- family: FlamanteRoma
fonts:
- asset: lib/assets/fonts/Flamante-Roma-Medium.ttf
- asset: lib/assets/fonts/Flamante-Roma-MediumItalic.ttf
- family: LatoBold
fonts:
- asset: lib/assets/fonts/Lato-Bold.ttf
- family: PingFang
fonts:
- asset: lib/assets/fonts/PingFang.ttf
⚠️本APP仅限于学习交流使用,项目中使用的图片及字体等资源如有侵权请联系作者删除
⚠️本APP接口数据均为mock,请勿用于其它商业目的
⚠️如使用本项目代码造成侵权与作者无关
我这求生欲🤔