从 PHP API 获取数据并在 Flutter Table 中展示

从 php api 获取数据并在 flutter table 中展示

本文档将指导你如何从 PHP API 获取数据,并使用 Flutter 的 `Table` 组件将其动态地展示出来。我们将重点解决 `NoSuchMethodError: The getter ‘length’ was called on null` 错误,并提供清晰的代码示例和注意事项,确保数据正确加载和显示。

从 PHP API 获取数据

首先,确保你已经创建了一个 Flutter 项目,并且已经添加了 http 依赖。你可以在 pubspec.yaml 文件中添加:

dependencies:  http: ^0.13.0 # 请使用最新版本

然后,运行 flutter pub get 来安装依赖。

接下来,创建一个 Model 类来映射 API 返回的数据。根据你提供的 JSON 示例,已经定义了 Model 和 Tender 类。这里再贴一下,方便查阅:

立即学习“PHP免费学习笔记(深入)”;

class Model {  Model({    this.id,    this.goodsRef,    this.loyer,    this.bnCode,    this.loyeeNo,    this.contactName,    this.contactTel,    this.bnDesc,    this.reqStatus,    this.eMail,    this.comments,    this.tender,    this.reqDate,    this.sscOffice,  });  final String id;  final int goodsRef;  final String loyer;  final String bnCode;  final int loyeeNo;  final dynamic contactName;  final dynamic contactTel;  final String bnDesc;  final String reqStatus;  final dynamic eMail;  final String comments;  final List tender;  final DateTime reqDate;  final dynamic sscOffice;  factory Model.fromJson(Map json) => Model(    id: json["u0024id"] == null ? null : json["u0024id"],    goodsRef: json["goods_ref"] == null ? null : json["goods_ref"],    loyer: json["loyer"] == null ? null : json["loyer"],    bnCode: json["bn_code"] == null ? null : json["bn_code"],    loyeeNo: json["loyee_no"] == null ? null : json["loyee_no"],    contactName: json["contact_name"],    contactTel: json["contact_tel"],    bnDesc: json["bn_desc"] == null ? null : json["bn_desc"],    reqStatus: json["req_status"] == null ? null : json["req_status"],    eMail: json["e_mail"],    comments: json["comments"] == null ? null : json["comments"],    tender: json["tender"] == null ? null : List.from(json["tender"].map((x) => Tender.fromJson(x))),    reqDate: json["req_date"] == null ? null : DateTime.parse(json["req_date"]),    sscOffice: json["ssc_office"],  );  Map toJson() => {    "u0024id": id == null ? null : id,    "goods_ref": goodsRef == null ? null : goodsRef,    "loyer": loyer == null ? null : loyer,    "bn_code": bnCode == null ? null : bnCode,    "loyee_no": loyeeNo == null ? null : loyeeNo,    "contact_name": contactName,    "contact_tel": contactTel,    "bn_desc": bnDesc == null ? null : bnDesc,    "req_status": reqStatus == null ? null : reqStatus,    "e_mail": eMail,    "comments": comments == null ? null : comments,    "tender": tender == null ? null : List.from(tender.map((x) => x.toJson())),    "req_date": reqDate == null ? null : reqDate.toIso8601String(),    "ssc_office": sscOffice,  };}class Tender {  Tender({    this.id,    this.goodsRef,    this.inNo,    this.tenderNo,    this.closingDate,  });  final String id;  final int goodsRef;  final int inNo;  final String tenderNo;  final String closingDate;  factory Tender.fromJson(Map json) => Tender(    id: json["u0024id"] == null ? null : json["u0024id"],    goodsRef: json["goods_ref"] == null ? null : json["goods_ref"],    inNo: json["in_no"] == null ? null : json["in_no"],    tenderNo: json["tender_no"] == null ? null : json["tender_no"],    closingDate: json["closing_date"] == null ? null : json["closing_date"],  );  Map toJson() => {    "u0024id": id == null ? null : id,    "goods_ref": goodsRef == null ? null : goodsRef,    "in_no": inNo == null ? null : inNo,    "tender_no": tenderNo == null ? null : tenderNo,    "closing_date": closingDate == null ? null : closingDate,  };}

接下来,创建一个函数来从 API 获取数据:

import 'dart:convert';import 'package:http/http.dart' as http;import 'package:flutter/material.dart';Future<List> fetchItems(String email) async {  String apiurl = "YOUR_API_URL"; // 替换为你的 API URL  var response = await http.post(Uri.parse(apiurl), body: {    'username': email // 获取用户名  });  if (response.statusCode == 200) {    // 使用 utf8.decode 处理中文乱码问题    final decodedBody = utf8.decode(response.bodyBytes);    List jsonResponse = jsonDecode(decodedBody);    List model = jsonResponse.map((item) => Model.fromJson(item)).toList();    return model;  } else {    throw Exception('Failed to load data from API');  }}

注意:

将 YOUR_API_URL 替换为你的 PHP API 的实际 URL。使用了 utf8.decode(response.bodyBytes) 来处理中文乱码问题,确保API返回的编码是UTF-8。

在 Flutter Table 中展示数据

现在,我们可以使用 FutureBuilder 来异步获取数据,并在 Table 组件中展示数据。

class MyTable extends StatefulWidget {  @override  _MyTableState createState() => _MyTableState();}class _MyTableState extends State {  String email = "test@example.com"; // 替换为你的邮箱  Future<List> _dataFuture;  @override  void initState() {    super.initState();    _dataFuture = fetchItems(email);  }  @override  Widget build(BuildContext context) {    return Scaffold(      appBar: AppBar(title: Text('Data Table from API')),      body: FutureBuilder<List>(        future: _dataFuture,        builder: (context, snapshot) {          if (snapshot.connectionState == ConnectionState.waiting) {            return Center(child: CircularProgressIndicator());          } else if (snapshot.hasError) {            return Center(child: Text('Error: ${snapshot.error}'));          } else if (snapshot.hasData) {            return buildTable(snapshot.data);          } else {            return Center(child: Text('No data available'));          }        },      ),    );  }  Widget buildTable(List data) {    return SingleChildScrollView( // 确保表格在小屏幕上可以滚动      scrollDirection: Axis.horizontal,      child: Table(        border: TableBorder.all(width: 1, color: Colors.black45),        columnWidths: {          0: FixedColumnWidth(100.0), // 可以自定义列宽          1: FixedColumnWidth(150.0),          2: FixedColumnWidth(200.0),          3: FixedColumnWidth(100.0),        },        children: [          TableRow( // 表头            children: [              TableCell(child: Center(child: Padding(padding: EdgeInsets.all(5), child: Text('Goods Ref')))),              TableCell(child: Center(child: Padding(padding: EdgeInsets.all(5), child: Text('BN Code')))),              TableCell(child: Center(child: Padding(padding: EdgeInsets.all(5), child: Text('BN Desc')))),              TableCell(child: Center(child: Padding(padding: EdgeInsets.all(5), child: Text('Req Status')))),            ],          ),          ...data.map((item) {            return TableRow(              children: [                TableCell(child: Center(child: Padding(padding: EdgeInsets.all(5), child: Text(item.goodsRef?.toString() ?? '')))),                TableCell(child: Center(child: Padding(padding: EdgeInsets.all(5), child: Text(item.bnCode ?? '')))),                TableCell(child: Center(child: Padding(padding: EdgeInsets.all(5), child: Text(item.bnDesc ?? '')))),                TableCell(child: Center(child: Padding(padding: EdgeInsets.all(5), child: Text(item.reqStatus ?? '')))),              ],            );          }).toList(),        ],      ),    );  }}

关键点:

使用 FutureBuilder 来处理异步数据加载。在 buildTable 方法中,使用 data.map 来迭代数据并创建 TableRow。使用 item.propertyName ?? ” 来处理可能为 null 的值,避免 NoSuchMethodError 错误。 ?? 是 Dart 的 null-aware 运算符,如果 item.propertyName 为 null,则使用空字符串 ” 作为默认值。SingleChildScrollView 确保表格在小屏幕上可以滚动。添加了表头,使表格更易于理解。使用 columnWidths 来自定义列宽。

解决 NoSuchMethodError 错误

NoSuchMethodError: The getter ‘length’ was called on null 错误通常发生在尝试访问 null 值的属性时。在你的例子中,这很可能是因为 API 返回的数据中某些字段是 null,而你没有正确处理。

解决方法:

使用 null-aware 运算符 (??): 在访问可能为 null 的属性时,使用 ?? 运算符提供一个默认值。例如:Text(item.name ?? ”)。

检查 null 值: 在访问属性之前,可以使用 if (item.property != null) 来检查值是否为 null。

在 Model 类中处理 null 值: 在 Model 类的 fromJson 方法中,可以为可能为 null 的字段提供默认值。例如:

factory Model.fromJson(Map json) => Model(  // ...  bnDesc: json["bn_desc"] == null ? "" : json["bn_desc"],  // ...);

总结

本文档介绍了如何从 PHP API 获取数据,并在 Flutter 的 Table 组件中展示数据。通过使用 FutureBuilder、null-aware 运算符和适当的错误处理,你可以创建一个动态的、数据驱动的表格。记住,处理 API 返回的 null 值是避免 NoSuchMethodError 错误的关键。希望本教程能够帮助你成功地构建你的 Flutter 应用!

以上就是从 PHP API 获取数据并在 Flutter Table 中展示的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1324933.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月12日 11:33:28
下一篇 2025年12月12日 11:33:39

相关推荐

  • Yii2框架如何实现用户认证_Yii2框架用户认证系统构建

    Yii2实现用户认证需配置user组件并实现IdentityInterface接口,通过自定义用户类处理身份验证。首先在config/web.php中设置identityClass指向用户模型;该模型须实现findIdentity、findIdentityByAccessToken、getId、ge…

    好文分享 2025年12月12日
    000
  • PHP命令怎么管理服务器进程_PHP命令行管理服务进程方法

    答案:PHP可通过命令行结合系统工具实现进程管理。使用php script.php > log & 后台运行,通过PID文件防止重复启动,利用pcntl_fork()和posix_setsid()实现守护进程,结合supervisor或systemd提升稳定性,确保进程可控、可监控、不…

    2025年12月12日
    000
  • PHP实现:最大化图的边端点值之和

    本文旨在提供一个PHP解决方案,用于计算给定图的最大可能边端点值之和。通过构建顶点权重数组,并根据顶点连接的边的数量分配权重,该算法能够有效地优化总和。文中将详细介绍算法的实现逻辑,并提供PHP示例代码,帮助开发者理解和应用该解决方案。 在图论问题中,最大化边端点值之和是一个常见的优化问题。 给定一…

    2025年12月12日
    000
  • PHP中安全处理变量与数组索引:避免“未定义”警告的策略

    本教程深入探讨php中如何有效使用`isset()`和`empty()`函数来检测变量和数组索引的存在性及非空性,旨在帮助开发者避免常见的“未定义变量”和“未定义索引”警告。文章将提供实用的代码示例,并介绍php 7+的空合并运算符,以确保代码的健壮性和可维护性。 在PHP开发中,处理用户输入或从外…

    2025年12月12日
    000
  • PHP 函数实现数值条件分类教程

    本教程旨在指导如何在数据导入或处理过程中,利用php函数根据数值范围进行条件分类。我们将探讨两种实现方式:一种是将计算与分类逻辑封装在同一函数中,另一种则专注于纯粹的分类逻辑。通过使用清晰的条件判断(如守卫子句),确保代码的可读性和维护性,从而将数值(如计算结果)高效地映射到预定义的文本类别(如“好…

    2025年12月12日
    000
  • 在Sublime Text中配置Prettier PHP插件:理解其配置机制

    本文详细阐述了Prettier PHP插件的配置机制,重点介绍了如何通过package.json、.prettierrc等配置文件进行项目级设置。我们将探讨Prettier如何解析配置文件,其配置项的优先级,以及为何不提供全局配置以确保团队协作中的代码风格一致性。旨在帮助用户在Sublime Tex…

    2025年12月12日
    000
  • PHP 实现边端点值最大和算法详解

    本文旨在提供一种使用 PHP 语言解决“计算图中边端点可能的最大和”问题的详细教程。该问题涉及图的顶点和边,目标是为每个顶点分配权重,使得所有边的端点权重之和最大化。本文将深入解析算法思路,并提供可执行的 PHP 代码示例,同时也会讨论一些注意事项。 问题描述 给定一个图,由 N 个顶点和一些边组成…

    2025年12月12日
    000
  • PHP require_once 文件路径错误解决方案

    本文针对 PHP 中 `require_once` 函数在引入文件时出现 “failed to open stream” 和 “Failed opening required” 错误的问题,提供详细的解决方案。通过分析文件路径问题,结合 `realpa…

    2025年12月12日
    000
  • 突破YouTube API限制:获取超过20,000个视频并访问非公开视频

    本文旨在解决在使用YouTube API时遇到的两个常见问题:使用API Key时,视频获取数量被限制在20,000个以内,以及无法访问非公开视频。文章将解释API Key的限制,并提供使用OAuth 2.0进行身份验证以克服这些限制的详细步骤和示例代码,助你更有效地利用YouTube API。 在…

    2025年12月12日
    000
  • Symfony 缓存预热后参数处理机制详解

    本文旨在深入解析 Symfony 框架在执行 `cache:warmup` 命令后,参数的处理方式。重点探讨参数是否仍然从 `parameters.yml` 文件读取、是否被存储在缓存中,以及开发环境和生产环境之间是否存在差异。通过本文,你将全面了解 Symfony 的参数加载和缓存机制,避免因参数…

    2025年12月12日
    000
  • PHP中安全处理未定义变量与数组键:isset、empty与??操作符深度解析

    本文深入探讨php中如何有效避免“未定义变量”和“未定义数组键”警告。我们将详细解析`isset()`、`empty()`函数以及php 7+引入的空合并操作符`??`的正确用法,并通过示例代码展示如何在处理`$_post`等超全局变量时构建健壮的逻辑,确保代码的稳定性和可维护性。 在PHP开发中,…

    2025年12月12日
    000
  • PHP与JavaScript数据交互:在前端代码中安全高效地使用后端变量

    本文深入探讨了在前端javascript代码中集成php后端数据的方法。主要介绍了两种策略:利用json_encode在页面渲染时直接嵌入php变量,适用于初始加载的数据;以及通过ajax进行异步请求,适用于页面加载后动态获取或更新数据。文章强调了数据安全、性能考量及代码组织的重要性,并提供了具体的…

    2025年12月12日
    000
  • Laravel 管理后台集成:内容管理最佳实践

    本文档旨在指导开发者如何在 Laravel 框架下构建一个内容管理系统(CMS),并解决在前端页面展示管理后台数据时遇到的“Undefined variable”错误。我们将以博文管理和关于我们信息管理为例,详细讲解后台数据录入、编辑、展示的完整流程,并提供关键代码示例和注意事项,帮助开发者快速搭建…

    2025年12月12日
    000
  • 从 PHP API 获取数据并填充 Flutter 表格

    本文档旨在指导开发者如何从 PHP API 获取数据,并使用 Flutter 的 Table 组件将数据动态地填充到表格中。文章将涵盖数据模型的定义、API 数据的获取、JSON 解析以及表格的构建,同时提供代码示例和注意事项,帮助开发者解决常见的 NoSuchMethodError 问题。 数据模…

    2025年12月12日
    000
  • 使用PHP正则表达式提取Meta Description中的数字

    本文将介绍如何使用PHP的`preg_match`函数,配合正则表达式,从HTML meta description标签中提取包含逗号分隔符的数字。我们将提供一个通用的正则表达式,能够处理不同格式的描述文本,并给出详细的代码示例和解释,帮助开发者高效地提取所需数据。 在Web开发中,经常需要从HTM…

    2025年12月12日
    000
  • 从带URL参数的PHP页面获取HTML内容

    本文旨在解决在使用PHP的`ob_start()`函数时,如何正确地从带有URL参数的PHP页面获取HTML内容,以便进行后续处理,例如生成PDF。我们将探讨如何通过全局变量获取URL参数,并在被包含的PHP文件中使用它们,从而避免常见的错误。 在使用PHP进行页面渲染,特别是需要将PHP页面转换为…

    2025年12月12日
    000
  • 利用距离API高效筛选城市列表:按驾驶距离进行范围限定

    本文将指导读者如何高效地筛选城市列表,使其仅显示与指定“主位置”驾驶距离在75公里以内(含)的城市。我们将探讨传统网页抓取方法的局限性,并重点推荐使用专业的距离计算api(如通过rapidapi提供的服务)作为更可靠、高效的解决方案。文章将提供api使用流程、示例代码及注意事项,帮助开发者轻松实现地…

    2025年12月12日
    000
  • 解决 Laravel 项目中因路径分隔符混合导致的 ‘文件未找到’ 错误

    本文旨在解决在 laravel 项目中运行 `php artisan serve` 时,因路径分隔符混合(如 “ 和 `/`)导致 `require(…): failed to open stream: no such file or directory` 的文件未找到错误。…

    2025年12月12日
    000
  • 将PHP后端数据集成到JavaScript:两种核心策略

    在Web开发中,JavaScript作为客户端脚本语言,负责处理用户交互和页面动态效果;而PHP作为服务器端脚本语言,则负责处理业务逻辑和数据存储。当我们需要在JavaScript中利用PHP处理过的数据时,就面临一个核心挑战:如何将服务器端的数据安全、高效地传递到客户端。本文将深入探讨两种主要的解…

    2025年12月12日
    000
  • PHP如何配置FastCGI实时输出_PHP FastCGI实时输出设置

    要实现PHP实时输出,需关闭PHP和Nginx的缓冲并主动刷新;1. 修改php.ini:output_buffering = Off,implicit_flush = On;2. 代码中使用ob_flush()和flush();3. Nginx配置fastcgi_buffering off。 PH…

    2025年12月12日
    000

发表回复

登录后才能评论
关注微信