Flutter27,android面试宝典铁道出版社

Android程序员:我用SwipeRefreshLayout。

接下来我们就说说以上这些功能如何在Flutter里实现,先来两张截图感受一下:

新闻列表

新闻源我们使用的是https://newsapi.org。你只要申请一个apiKey就能从他家获取json格式的头条新闻数据。至于详情的话需要用webview直接打开对应的新闻url。

网络返回的JSON数据格式如图所示:

这里面"articles"字段的值是个jsonArray,内容是头条新闻的列表。在Android中我们可以用Gson来把json数据反序列化为对象。那再Flutter中如何来做反序列化呢?

首先我们引入必要的库:

pubspec.yaml加入以下内容

dependencies:

json_annotation: ^0.2.3

dev_dependencies:

build_runner: ^0.8.0

json_serializable: ^0.5.0

然后在终端中运行flutter packages get(或者点击"Packages Get"的提示,类似你更改.gradle文件以后Android Studio显示的同步提示)

接下来就是model类了

import ‘package:json_annotation/json_annotation.dart’;

part “news.g.dart”;

@JsonSerializable()

class News extends Object with _$NewsSerializerMixin {

final String author;

final String title;

final String description;

final String url;

final String urlToImage;

final String publishedAt;

final Source source;

News(this.author,

this.title,

this.description,

this.url,

this.urlToImage,

this.publishedAt,

this.source);

factory News.fromJson(Map<String, dynamic> json) => _$NewsFromJson(json);

}

@JsonSerializable()

class Source extends Object with _$SourceSerializerMixin {

final String id;

final String name;

Source(this.id, this.name);

factory Source.fromJson(Map<String, dynamic> json) => _$SourceFromJson(json);

}

@JsonSerializable()

class NewsList extends Object with _$NewsListSerializerMixin {

final String status;

final int totalResults;

final List articles;

final code;

final message;

NewsList(this.status, this.totalResults, this.articles, this.code, this.message);

factory NewsList.fromJson(Map<String, dynamic> json) => _$NewsListFromJson(json);

}

看起来既有熟悉的字段,又有陌生的注解和代码?没关系,只要你按照这里的要求来做就行了。可以看出反序列化是在_$NewsListFromJson(json);里完成的。那么这个函数从何而来呢?这需要我们运行命令flutter packages pub run build_runner build来生成对应的代码。生成的代码存放在news.g.dart中。

至此model类以及反序列化我们就已经做完了,那么下面就看看网络请求怎么来实现。

网络请求

对应于Android中的OkHttp, Flutter中的网络请求库是http.dart。如下所示,代码比较简单

import ‘dart:async’;

import ‘dart:convert’;

import ‘package:flutter/foundation.dart’;

import ‘package:http/http.dart’ as http;

import ‘package:flutter_news/model/news.dart’;

class NewsApi {

static Future getHeadLines({String category: “general”, int page: 0}) async {

final response = await http.get(

“https://newsapi.org/v2/top-headlines?country=us&apiKey=efaf5fb66d104385ad40c73d4fd4acb1&page=KaTeX parse error: Expected 'EOF', got '&' at position 5: page&̲category=category”);

return compute(parseResult, response.body);

}

static NewsList parseResult(String respond) {

return NewsList.fromJson(json.decode(respond));

}

}

我们都知道在Android中网络请求需要在子线程来做,否则会阻塞主线程;请求的结果通过callback来返回给主线程。

而在Flutter中则更加简洁,通过asyncawait,避免了难看的callback代码嵌套。

函数getHeadLines用来做http请求,在走到await的时候会"等待"后面的http.get函数执行完毕,返回值赋给response,之后继续执行函数体中的后续代码。注意,这里的"等待"并不是阻塞在那里,而只是告诉系统,后续的代码需要在await后面的表达式结束之后执行。你可以把await那一行以下的代码理解为Android网络调用中的callback。实际的运行机制其实是比较复杂的,需要另写文章详细说明。

在请求得到返回值response以后就要做json反序列化了。因为反序列化也有可能是个耗时任务,有可能会阻塞ui. 这里我们用过Flutter提供的compute函数把反序列化放在另外的isolate去完成。这里你可以先把isolate当成是Java里的线程。compute函数的第一个参数parseResult是真正进行反序列化操作的函数。大家可以感受一下,函数作为参数还是比较方便的。

Model层我们已经有了,那么接下来就看下View层怎么来搭建吧。

界面

在做Android原生开发的时候。我们一般会用XML来搭建界面,里面是一个一个的View。而在Flutter中,和View等同的是Widget。Flutter app的界面就是由一个个Widget拼接起来的。而且Widget都是写在代码中的,目前没有用xml等其他搭建UI的方式,这也是目前Flutter开发被吐槽的点,代码中各种嵌套的Widget还是比较令人酸爽的。

Widget分为StatelessWidget(无状态的)和StatefulWidget(有状态的)。无状态是指这个Widget的状态会发生改变,类比如Android中显示固定字符串的TextView或者显示固定图标的ImageView。反之有状态则是指这个Widget在显示期间内状态会发生改变,就比如我们在做网络请求的时候会显示一个Progress图标,请求回来数据以后会显示一个列表。这就是状态发生了变化。当需要变更状态的时候,只要调用setState。StatefulWidget的build函数会被调用,根据新的state来重建UI,是不是听起来和Android中的notifyDataSetChanged有点像?

让我们自上而下的看一下main.dart的代码吧

// 我是入口,类似于java中的 static main()

void main() => runApp(new MyApp());

// 我是最外层的容器,我不关心里面内容的变化,所以是无状态的。

class MyApp extends StatelessWidget {

@override

Widget build(BuildContext context) {

//返回给你一个MaterialApp,至于内部还有啥,看参数

return MaterialApp(

title: ‘Headlines’,

theme: ThemeData(

primarySwatch: Colors.blue,

),

// 这个Widget是我们自定义的

home: HeadLinePage(title: ‘Headlines’),

);

}

入口的这些代码都是常规操作。不细说了。

这里顺便说一句,一个.dart文件中是可以包含多个在最外层的类的,这点和Java是不一样的,需要习惯一下。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

最后

最后这里放上我这段时间复习的资料,这个资料也是偶然一位朋友分享给我的,里面包含了腾讯、字节跳动、阿里、百度2020-2021面试真题解析,并且把每个技术点整理成了视频和PDF(知识脉络 + 诸多细节)。

还有 高级架构技术进阶脑图、高级进阶架构资料 帮助大家学习提升进阶,这里我也免费分享给大家也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

有需要的朋友可以点击:**Android面试资料**免费领取~

一起互勉~

是偶然一位朋友分享给我的,里面包含了腾讯、字节跳动、阿里、百度2020-2021面试真题解析,并且把每个技术点整理成了视频和PDF(知识脉络 + 诸多细节)。

还有 高级架构技术进阶脑图、高级进阶架构资料 帮助大家学习提升进阶,这里我也免费分享给大家也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

有需要的朋友可以点击:**Android面试资料**免费领取~

[外链图片转存中…(img-XiRbroEy-1710659315835)]

[外链图片转存中…(img-yJiehShw-1710659315836)]

一起互勉~

  • 16
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值