React 版 Mung
React-Native 版 Mung
Flutter 版 Mung
Mung-Flutter
1. Mung-Flutter:是一个基于 Flutter 编写,使用豆瓣开源 API 开发的一个项目。
2. 功能概述
- 启动页 :添加了启动页主要是让最开始进入时不至于显示白屏。
- 数据保存 :支持断网加载缓存数据。
- 主题换肤 :现在只支持切换主题颜色,本项目没几张图片。
- 查看电影详情 :支持查看电影详情包括评论。
- 一键搜索 :支持标签和语句查找相关的电影。
- 查看剧照 : 支持缩放图片。
-
3.1 动态演示 (Android 版)
3.2 运行结果图
4. 使用到的框架
- flutter_swiper:Banner 栏图片轮播的效果。
- rxdart:和 Rxjava、RxJs、RxSwift 差不多,这里主要用它的 BehaviorSubject 配合 Bloc 模式实现状态管理。
- shared_preferences:简单的数据保存,比较细致的数据存储如列表等还是建议使用数据库。
- dio:实现网络请求,一个非常不错的三方网络包,功能非常多,如果刚入门或者项目比较急建议使用这个。
- flutter_spinkit : 加载时显示的加载组件,挺不错,建议看下。
- photo_view:图片缩放组件,因为安卓里的 photoview 正好选了,使用了一个简单的功能,暂时没发现问题。
5. 项目全局状态管理
现在据我了解的比较成熟的状态管理有。
-
- InheritedWidget(自带的其他三方好像都是基于它开发,只是封装了下,更加方便)
-
- scoped_model:不错。
-
- redux 和前端的 redux 是一个意思,但我写过 demo 用过,个人愚见:差远了。
-
- Bloc:(Business Logic Component)paolo soares 和 cong hui 在 2018 年 Google dartconf 上提出的, 它其实是一个模式 InheritedWidget+stream 配合使用。
本项目使用的就是 Bloc。
6. 思考
这个开发的第一个 flutter,都有这个项目来说该用的主流框架都恰到好处的用了,因为项目太小,适合入门和快速开发。对于 flutter 个人感觉。
-
- 上个月看了一个消息 Flutter 团队好像在今年不会推出热更新功能,好像是基于安全和可实现性考虑,这里要说下 flutter 编译模式:开发阶段使用的是 Kernel Snapshot 模式编译,生产模式使用 AOT。
-
- flutter 上月好像推出了 web 端和桌面的适配,这个应该对 flutter 发展有很大帮助。
-
- 我之前一年多一直使用 React-Native 开发项目,感觉 Flutter 的组件比 RN 多,而且多很多,组件兼容性更好,而且更精致,但是嵌套的模式真心丑,而且巨乱,我开发时把组件拆分成多个函数这样会让界面清新一点。
-
- 状态管理,暂时还没有一个绝对好的状态管理功能,现在有些项目使用 bloc 或者 bloc+redux,但个人认为不久的将来会有一个好的状态管理功能占据绝对的地址,想 RN 的 redux、mobx 一样。
-
- 组件生命周期函数很少,尤其是开发大型项目时,之前使用 RN 开发时就觉得 RN 比原生安卓生命周期少,自己还得去添加全局监听去管理生命周期,flutter 就更少了。
-
- 性能,应该 flutter,网上一大堆对比文章一番一大把,个人使用也明显感觉到 flutter 性能很好,这是现实原理的问题,尤其是列表,比 fRN 好很多,而且动画等也多,自定义组件还没看,不做评价。
-
- 社区,毫无疑问 RN 社区会比 Flutter 对于现在这个时间段来说,而且 RN 支持热更新对原生加(RN、Flutter)来说,RN 也更站优势,三方组件来说 RN 已经很多了,开源项目比较多。
7. 提示
2019-5-12 左右豆瓣把开源 API 关了,现在使用的别的开发者的地址,项目 Baser_url 是抽出来的后期可以自己改,现在项目使用的是 https://douban.uieee.com/v2,可以正常运行。
8. 下载地址
- 安卓版
- ios 版(没有企业账号 -????)