Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/heruijun/flutter_boss
flutter仿BOSS直聘(二),大前端技术实现
https://github.com/heruijun/flutter_boss
Last synced: about 2 months ago
JSON representation
flutter仿BOSS直聘(二),大前端技术实现
- Host: GitHub
- URL: https://github.com/heruijun/flutter_boss
- Owner: heruijun
- Created: 2018-03-12T13:59:48.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2019-01-20T07:48:23.000Z (almost 6 years ago)
- Last Synced: 2024-08-05T19:34:31.829Z (5 months ago)
- Language: Dart
- Homepage:
- Size: 5.85 MB
- Stars: 966
- Watchers: 34
- Forks: 245
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-flutter-app - 仿boss直聘
README
# flutter仿BOSS直聘(二),大前端技术实现
## 项目简介
记得上一篇的写作时间还在2018年2月份,已经很久没更新了,而flutter的版本更新了好几次,自flutter 1.0正式版推出之后,一直有打算把之前的项目重写一下,因为flutter本身更新了许多新特性,老的已经是过去式了,也老有人来问我,之前的项目运行不了,是的,因为sdk太老了,而且之前的项目纯粹是练手玩。在过去的这段时间里,踊跃出了很多关于flutter的技术文章和开源项目例子,基本上每天都有,同比RN刚出来时,热情度远超RN。于是,笔者怀着对新技术热情的学习态度重写了这个开源项目,并且后续也会不断完善。
为什么选仿BOSS直聘作为题材?
因为这款APP相信大家都在使用,里面组件繁多且有一定复杂度,能衍生出来许多基于flutter组件库的子项目,里面有些功能,比如地图,IM,后面都会使用flutter来实现。为了让项目更接近真实,这次连服务端也实现了。先把开源地址提供给大家:## github地址:
服务端版本:[flutter仿boss直聘服务端](https://github.com/heruijun/flutter-boss-server).flutter版本:[flutter仿boss直聘](https://github.com/heruijun/flutter_boss).
## 项目效果图:
![img](https://user-gold-cdn.xitu.io/2019/1/20/1686a0c4b2fb9cda?w=252&h=528&f=gif&s=1194865)## 相关技术点
服务端:
* 基于puppeteer + mongo + nodejs实现爬虫服务器,使用nuxt + koa2 + vue实现服务端渲染以及api服务接口。这里就不过多占用篇幅了,本文主要还是讲flutter,对前端感兴趣的会另外分享相关技术话题。flutter端:
* 项目中使用以下组件,请记住一句咒语:flutter一切皆组件。
Container, Row, Column, Flex, ListView, CustomListView, Wrap, Padding, Center, Future, FutureBuilder, Expanded, Navigator, BottomNavigationBar, GesureDetector, Listener, CircleAvatar等以及一些自定义组件。
* 布局语义化,不滥用布局组件,并尽量简化组件嵌套结构## 技术细节
* 实现启动画面,在启动1.5秒后,跳转到app里,并且把启动画面的路由remove掉。```
Navigator.of(context).pushAndRemoveUntil(
PageRouteBuilder(
pageBuilder: (BuildContext context, Animation animation,
Animation secondaryAnimation) {
return AnimatedBuilder(
animation: animation,
builder: (BuildContext context, Widget child) {
return Opacity(
opacity: animation.value,
child: new MainPage(title: 'Boss直聘'),
);
},
);
},
transitionDuration: Duration(milliseconds: 300),
),
(Route route) => route == null);
```* 列表页面,没啥好说的,ListView大家应该都用过,只是需要记住一点,列表再跳转详情时需要记录当前列表的滚动位置,只需加入以下代码即可:
`key: new PageStorageKey('key-name')`* Hero动画,在详情页面里,用了2处Hero动画,Hero动画是在route切换过程中执行的动画。需要当前页和目标页一一对应起来。
```
Hero(
tag: heroLogo,
child: ClipRRect(
borderRadius: new BorderRadius.circular(8.0),
child: Image.network(
widget.company.logo,
width: 70,
height: 70,
),
),
)),
```* CustomListView滑动时appBar显示隐藏title。大家都知道,flexibleSpace里的CollapseMode.parallax属性可以在屏幕滚动时把title移动到appBar里,可实际上,布局是定制的,实现不了官方的那种效果,于是通过监听ScrollController并计算滚动位置的方式修改state属性让appBar的title根据滚动位置显示隐藏。
```
_scrollListener() {
setState(() {
if (_scrollController.offset < 56 && _isShow) {
_isShow = false;
} else if (_scrollController.offset >= 56 && _isShow == false) {
_isShow = true;
}
});
}
```## TODO-LIST
* 公司详情页slidePanel控件实现
* 公共弹层组件封装
* 消息列表控件封装并实现测滑删除功能## qq技术Flutter讨论千人群号:468010872
![img](https://user-gold-cdn.xitu.io/2019/1/20/1686a0d003f4a331?w=541&h=741&f=jpeg&s=55386)## 联系方式
微信:heruijun2258,注明来意。