Flutter27,android面试八股文

本文介绍了在Flutter中如何进行网络请求,使用http库进行GET操作并利用JsonSerializable进行反序列化。同时,讨论了如何构建界面,指出在Flutter中Widget相当于Android中的View,并解释了无状态和有状态Widget的概念。示例展示了如何创建自定义StatefulWidget来展示新闻列表,使用FadeInImage实现图片加载。最后,简要提到了Flutter项目的目录结构。
摘要由CSDN通过智能技术生成

@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 {

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值