Flutter实战

根据杜文的Flutter实战.将最后一个实例篇转换为项目并运行起来

1.学习连接地址

https://book.flutterchina.club/chapter15/models.html

2.项目地址

https://github.com/FQDEVER/GithubClientDemo.git

3.所有框架

dependencies:
flutter:
sdk: flutter
flutter_localizations:
sdk: flutter
json_annotation: ^2.0.0
cached_network_image: ^2.1.0+1
cupertino_icons: ^0.1.3`

dev_dependencies:
    flutter_test:
    sdk: flutter
    build_runner: ^1.0.0
    json_serializable: ^2.0.0
    json_model: ^0.0.2
    shared_preferences: ^0.5.6
    dio: ^3.0.9
    provider: ^4.0.5
    oktoast: ^2.3.2
    flukit: ^1.0.2

4.学习思路

Model类定义

可以使用json_serializable,josn_model,json_annotation使用命令flutter packages pub run json_model执行获取对应json的dart模型
当然也可以使用一个网站.将json数据copy进去.获取对应的model.地址:https://javiercbk.github.io/json_to_dart/

数据持久化

使用shared_preferences包对需要的信息做持久化处理

全局变量与共享变量

借鉴:应用程序中通常会包含一些贯穿APP生命周期的变量信息,这些信息在APP大多数地方可能都会被用到,比如当前用户信息、Local信息等。在Flutter中我们把需要全局共享的信息分为两类:全局变量和共享状态。全局变量就是单纯指会贯穿整个APP生命周期的变量,用于单纯的保存一些信息,或者封装一些全局工具和方法的对象。而共享状态则是指哪些需要跨组件或跨路由共享的信息,这些信息通常也是全局变量,而共享状态和全局变量的不同在于前者发生改变时需要通知所有使用该状态的组件,而后者不需要。为此,我们将全局变量和共享状态分开单独管理。
全局变量是固定不变的如统一的网络错误提示语等.共享变量是会影响所有相关的Widget.并且随着共享变量而变化.如主题.国际化.字体等

网络接口

现在使用比较的多的还是dio网络库.如果需要做缓存可以研究一下.如果不是很复杂的请求和要求不高.可以简单地了解使用即可

  // 登录接口,登录成功后返回用户信息
  Future<User> login(String login, String pwd) async {
    String basic = 'Basic ' + base64.encode(utf8.encode('$login:$pwd'));
    var r = await dio.get(
      "/users/$login",
      options: _options.merge(headers: {
        HttpHeaders.authorizationHeader: basic
      }, extra: {
        "noCache": true, //本接口禁用缓存
      }),
    );
    //登录成功后更新公共头(authorization),此后的所有请求都会带上用户身份信息
    dio.options.headers[HttpHeaders.authorizationHeader] = basic;
    //清空所有缓存
    Global.netCache.cache.clear();
    //更新profile中的token信息
    Global.profile.token = basic;
    return User.fromJson(r.data);
  }

5.主要的逻辑分析:

a.国际化.我使用的是Flutteri18n这个插件.详细使用可参考项目


image.png

相关代码:

      MaterialApp(
          theme: ThemeData(
            primarySwatch: themeModel.theme,
            visualDensity: VisualDensity.adaptivePlatformDensity,
          ),
          onGenerateTitle: (context){
            return S.of(context).app_title;
          },
          home: HomeRoute(),
          locale: localeModel.getLocale(),
          supportedLocales: S.delegate.supportedLocales,
          localizationsDelegates: const [
            S.delegate,
            GlobalMaterialLocalizations.delegate,
            GlobalWidgetsLocalizations.delegate,
          ],
          localeListResolutionCallback: (List<Locale> locales,Iterable<Locale> supportedLocales){
            if(localeModel.getLocale() != null){
              //如果已选定语言,则不跟随系统
              return localeModel.getLocale();
            } else{
              Locale locale;
              Locale _locale = locales.first;
              if(supportedLocales.contains(_locale)){
                locale = _locale;
              }else{
                locale = Locale("en","US");
              }
              return locale;
            }
          },
         ),

b.用于路由跳转

相关代码:

          routes: <String,WidgetBuilder>{
            "login": (context) => LoginRoute(),
            "themes": (context) => ThemeChangeRoute(),
            "language": (context) => LanguageRoute(),
          },

使用:

       Navigator.of(context).pushNamed("login");

c.登录与数据页面切换逻辑

使用状态管理Provider.可以使用Consumer指定访问的模型类型.例如: Consumer<UserModel>.
当你在模型中调用 notifyListeners() 时,所有和 Consumer 相关的 builder 方法都会被调用,即可更新更新界面

通过这个状态管理插件.即可实时更新未登录/登录界面.语言环境与主题的切换

最后:该本书细细品读有很多细节值得学习.特别最后的实例项目.有一些架构相关的设计思路
参考:https://book.flutterchina.club/chapter15/models.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352