我的编程空间,编程开发者的网络收藏夹
学习永远不晚

flutter中的网络请求数据获取详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

flutter中的网络请求数据获取详解

跨平台的http请求

http包提供了最简单的发起请求的方式,并且这个包在WEB,ANDROID,IOS上都得到了很好的支持。

需要注意的是,在某些特定的平台上需要设置一些额外的内容,比如:

ANDROID上必须在manifest(AndroidManifest.xml)文件中进行声明。

<manifest xmlns:android...>
 ...
 <uses-permission android:name="android.permission.INTERNET" />
 <application ...
</manifest>

macOS上必须在.entitlements进行配置。

<key>com.apple.security.network.client</key>
<true/>

请求数据

从网络上请求数据大致分为四步:

  • 添加http
  • 通过http包发起请求
  • 将收到的响应数据转为客户端可用的数据
  • 展示用户界面

添加http包

我们只需要在pub.dev文件中添加配置即可:

dependencies:
  http: <latest_version>

然后在代码中导入http包:

import 'package:http/http.dart' as http;

另外,在安卓中我们需要添加网络权限:

<!-- Required to fetch data from the internet. -->
<uses-permission android:name="android.permission.INTERNET" />

发起请求

发起请求很简单:

Future<http.Response> fetchAlbum() {
  return http.get(Uri.parse('https://jsonplaceholder.typicode.com/albums/1'));
}

http.get()方法返回一个Future类的数据,这个数据包含了收到的响应数据。 Future是用于处理异步操作的核心Dart类。Future对象表示将来某个时间可能出现的值或错误。 http.Response类包含从成功的http调用接收的数据。

将响应转为常用对象

虽然发出网络请求很容易,但使用原始的Future<http.Response>并不是很方便。为了让我们的开发更简单,我们可以将http.Response转换为Dart对象。

首先,创建一个包含网络请求数据的Album类。它包括一个工厂构造函数,用于从JSON创建Album。

class Album {
  final int userId;
  final int id;
  final String title;
  const Album({
    required this.userId,
    required this.id,
    required this.title,
  });
  factory Album.fromJson(Map<String, dynamic> json) {
    return Album(
      userId: json['userId'],
      id: json['id'],
      title: json['title'],
    );
  }
}

然后,我们使用以下步骤更新fetchAlbum()函数以返回Future<Album>

  • 使用dart:Convert包将响应体转换为JSON映射。
  • 如果服务器确实返回了状态代码为200的OK响应,则使用fromJson()工厂方法将JSON映射转换为Album
  • 如果服务器没有返回状态代码为200的OK响应,则抛出异常。(即使在“404 Not Found”服务器响应的情况下,也会抛出异常。不要返回null。这在检查快照中的数据时很重要,如下所示。)
Future<Album> fetchAlbum() async {
  final response = await http
      .get(Uri.parse('https://jsonplaceholder.typicode.com/albums/1'));
  if (response.statusCode == 200) {
    // If the server did return a 200 OK response,
    // then parse the JSON.
    return Album.fromJson(jsonDecode(response.body));
  } else {
    // If the server did not return a 200 OK response,
    // then throw an exception.
    throw Exception('Failed to load album');
  }
}

获取数据

我们可以在initState()didChangeDependencies()方法中调用fetchAlbum()方法。

initState()方法只调用一次,然后再也不会调用。如果我们想选择重新加载API以响应InheritedWidget的更改,我们可以将调用放入didChangeDependencies()方法中。

class _MyAppState extends State<MyApp> {
  late Future<Album> futureAlbum;
  @override
  void initState() {
    super.initState();
    futureAlbum = fetchAlbum();
  }
  // ···
}

展示数据

要在屏幕上显示数据,我们可以使用FutureBuilder组件。FutureBuilder组件随Flutter一起提供,可以轻松处理异步数据源。

我们需要提供两个参数:

  • 具体的Future
  • builder方法,用来告诉系统渲染什么内容,根据状态可以选择加载中等等。
FutureBuilder<Album>(
  future: futureAlbum,
  builder: (context, snapshot) {
    if (snapshot.hasData) {
      return Text(snapshot.data!.title);
    } else if (snapshot.hasError) {
      return Text('${snapshot.error}');
    }
    // By default, show a loading spinner.
    return const CircularProgressIndicator();
  },
)

为什么要在initstate中获取数据?

虽然在build()中调用很方便,但不建议将API调用放在build()方法中。

Flutter每次需要更改视图中的任何内容时都会调用build()方法,这种情况经常发生。如果将fetchAlbum()方法放置在build()中,则会在每次重建时重复调用,导致应用程序速度减慢。

以上就是flutter中的网络请求数据获取详解的详细内容,更多关于flutter网络请求数据获取的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

flutter中的网络请求数据获取详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

flutter中的网络请求数据获取详解

这篇文章主要为大家介绍了flutter中的网络请求数据获取示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-11

【Java 进阶篇】Java Request 获取请求头数据详解

在Java Web开发中,获取HTTP请求的请求头数据是一项常见任务。HTTP请求的请求头包含了客户端发送给服务器的额外信息,这些信息对于服务器来说很重要,因为它们可以包含用户代理、授权信息、Cookies等内容。在Java中,可以使用H
【Java 进阶篇】Java Request 获取请求头数据详解
2023-12-23

SpringBoot如何获取Get请求参数详解

SpringBoot为我们封装了许多简便的获取请求参数的方法,下面这篇文章主要给大家介绍了关于SpringBoot如何获取Get请求参数的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
2022-12-08

Java中SpringMVC怎么获取请求数据

本文小编为大家详细介绍“Java中SpringMVC怎么获取请求数据”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java中SpringMVC怎么获取请求数据”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.获
2023-06-29

uni-app网络请求、数据缓存实例详解

这篇文章主要介绍了uni-app网络请求、数据缓存的相关知识,本文通过实例代码给大家讲解的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-11-16

如何在 Java 中获取注解的请求参数值?(Java注解怎么获取请求参数值)

在Java开发中,注解是一种非常强大的工具,它可以为代码添加元数据,提供额外的信息和功能。其中,获取注解中的请求参数值是一个常见的需求,本文将详细介绍如何在Java中实现这一功能。一、注解的基本概念注解是Java5
如何在 Java 中获取注解的请求参数值?(Java注解怎么获取请求参数值)
Java2024-12-14

微信小程序网络数据请求的实现详解

这篇文章主要为大家介绍了微信小程序网络数据请求的实现讲解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

微信小程序网络数据请求服务实现详解

这篇文章主要介绍了微信小程序网络数据请求服务,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2022-11-13

Python获取接口请求耗时的方法详解

你想知道我们请求一个url的时候,握手和请求资源分别占用多长时间么?今天我们就来使用python写个小案例来看看,感兴趣的可以跟随小编一起了解一下
2023-05-16

java中springMVC获取请求参数的方法

这篇文章主要介绍了java中springMVC获取请求参数的方法,springmvc是spring框架的一个模块,springmvc和spring无需通过中间整合层进行整合,需要的朋友可以参考下
2023-05-18

Android开发中的几种网络请求方式详解

Android应用经常会和服务器端交互,这就需要手机客户端发送网络请求,下面介绍四种常用网络请求方式,我这边是通过Android单元测试来完成这四种方法的,还不清楚Android的单元测试的同学们请看Android开发技巧总结中的Andro
2022-06-06

python如何获取http请求响应头headers中的数据

本篇内容介绍了“python如何获取http请求响应头headers中的数据”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!例如我要测试一个创
2023-06-29

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录