国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統(tǒng) > Android > 正文

flutter實現(xiàn)仿boss直聘功能

2019-12-12 01:06:42
字體:
供稿:網(wǎng)友

Flutter是Google使用Dart語言開發(fā)的移動應用開發(fā)框架,使用一套Dart代碼就能構(gòu)建高性能、高保真的iOS和Android應用程序,并且在排版、圖標、滾動、點擊等方面實現(xiàn)零差異。

2年前,RN剛出來時做了個仿拉鉤的demo,react-native-lagou.
這次flutter來了,想感受一下,索性用目前flutter的版本寫的一個仿boss直聘應用。
時間有限,沒完全仿照,去掉了一些功能,但是界面風格一致,有參考價值。

github地址:flutter仿boss直聘.

感悟

  1. 與一些文章里介紹的非常相似,如果會RN,那么學起來會很快,flutter借鑒了RN的組件化思想,路由機制,狀態(tài)機等。
  2. Dart語法有些奇葩,但掌握之后,開發(fā)效率會很快,整個demo加起來開發(fā)了2天不到。
  3. 可以同時在android和ios運行。
  4. 性能很快,超過RN,因為沒有bridge層。
  5. 還是要多看官方文檔和源碼,才能碰到問題解決。
  6. IDE還不是很友好,hot reload有時無效。
  7. 還是比RN要復雜一些的。

先上效果

部署到手機

確保flutter正確安裝之后,進入目錄運行flutter run --release

環(huán)境問題

如果flutter環(huán)境有問題,在.bash_profile里加上如下內(nèi)容

export PUB_HOSTED_URL=https://pub.flutter-io.cnexport FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cnexport PATH=`pwd`/flutter/bin:$PATH

涉及技術(shù)點

1.Theme主題設置  

theme: new ThemeData(    primaryIconTheme: const IconThemeData(color: Colors.white),    brightness: Brightness.light,    primaryColor: new Color.fromARGB(255, 0, 215, 198),    accentColor: Colors.cyan[300],   )

2.自定義TabBar

  @override   Widget build(BuildContext context) {    assert(debugCheckHasMaterial(context));      double height = _kTextAndIconTabHeight;    Widget label = new Column(      mainAxisAlignment: MainAxisAlignment.center,      crossAxisAlignment: CrossAxisAlignment.center,      children: <Widget>[       new Container(        child: new Image(         image: new AssetImage(this.icon),         height: 30.0,         width: 30.0,        ),        margin: const EdgeInsets.only(bottom: _kMarginBottom),       ),       _buildLabelText()      ]    );   }

3.MD風格及一些組件應用

 new SliverAppBar(   expandedHeight: _appBarHeight,   pinned: _appBarBehavior == AppBarBehavior.pinned,   floating: _appBarBehavior == AppBarBehavior.floating ||     _appBarBehavior == AppBarBehavior.snapping,   snap: _appBarBehavior == AppBarBehavior.snapping,   flexibleSpace: new FlexibleSpaceBar(    title: new Text(_company.name,      style: new TextStyle(color: Colors.white)),    background: new Stack(     fit: StackFit.expand,     children: <Widget>[      new Image.network(       'https://img.bosszhipin.com/beijin/mcs/chatphoto/20170725/861159df793857d6cb984b52db4d4c9c.jpg',       fit: BoxFit.cover,       height: _appBarHeight,      ),     ],    ),   ),  )

4.解決了官方demo里路由跳轉(zhuǎn)效果卡頓的問題

Navigator.of(context).push(new PageRouteBuilder(    opaque: false,    pageBuilder: (BuildContext context, _, __) {     return new CompanyDetail(company);    },    transitionsBuilder: (_, Animation<double> animation, __, Widget child) {     return new FadeTransition(      opacity: animation,      child: new SlideTransition(position: new Tween<Offset>(       begin: const Offset(0.0, 1.0),       end: Offset.zero,      ).animate(animation), child: child),     );    }  ))

TODO

  1. 下拉篩選組件
  2. mock server,模擬真實請求
  3. 分頁
  4. 目錄結(jié)構(gòu)調(diào)整,更符合生產(chǎn)環(huán)境
  5. viewpager輪播圖
  6. 路由機制封裝

總結(jié)

以上所述是小編給大家介紹的flutter實現(xiàn)仿boss直聘,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網(wǎng)網(wǎng)站的支持!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 仁寿县| 佛坪县| 方正县| 哈密市| 阳谷县| 合肥市| 吐鲁番市| 称多县| 宜都市| 丹棱县| 乌兰察布市| 乐陵市| 陈巴尔虎旗| 台中市| 聂拉木县| 离岛区| 会理县| 福安市| 龙口市| 扎赉特旗| 黄陵县| 夹江县| 太湖县| 陕西省| 元氏县| 马尔康县| 商丘市| 渭南市| 大荔县| 双柏县| 高淳县| 连云港市| 华容县| 彭山县| 泰宁县| 鲜城| 德清县| 百色市| 镇江市| 阿城市| 贡山|