<大厂实战场景> ~ Flutter&鸿蒙next 解析后端返回的 HTML 数据详解

简介: 本文介绍了如何在 Flutter 中解析后端返回的 HTML 数据。首先解释了 HTML 解析的概念,然后详细介绍了使用 `http` 和 `html` 库的步骤,包括添加依赖、获取 HTML 数据、解析 HTML 内容和在 Flutter UI 中显示解析结果。通过具体的代码示例,展示了如何从 URL 获取 HTML 并提取特定信息,如链接列表。希望本文能帮助你在 Flutter 应用中更好地处理 HTML 数据。

写在前面
在现代应用中,后端服务经常返回 HTML 数据,特别是在进行 web scraping 或处理某些 API 时。Flutter 提供了强大的工具来处理和解析这些数据。本文将深入探讨如何在 Flutter 中解析后端返回的 HTML 数据,使用的工具和步骤,以及一些实际的示例。

  1. 什么是 HTML 解析?
    HTML 解析是将 HTML 文档转换为结构化的数据,以便程序可以方便地访问和操作。这在处理来自网络的内容时尤为重要,特别是当你需要提取特定的信息时。

  2. Flutter 中的 HTML 解析库
    在 Flutter 中,有几个流行的库可以帮助解析 HTML 数据:

html: 提供 DOM 操作和解析功能。
http: 用于发送 HTTP 请求,获取 HTML 数据。
2.1 添加依赖
在 pubspec.yaml 文件中添加以下依赖:

yaml

dependencies:
flutter:
sdk: flutter
http: ^0.14.0
html: ^0.15.0
运行 flutter pub get 命令来安装这些依赖。

  1. 获取 HTML 数据
    使用 http 库从后端获取 HTML 数据。下面是一个简单的示例,演示如何从某个 URL 获取 HTML 内容。

3.1 获取 HTML 示例
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;

void main() {
runApp(MyApp());
}

class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'HTML Parsing Demo',
home: HomeScreen(),
);
}
}

class HomeScreen extends StatelessWidget {
Future fetchHtml() async {
final response = await http.get(Uri.parse('https://example.com'));

if (response.statusCode == 200) {
  return response.body;
} else {
  throw Exception('Failed to load HTML');
}

}

@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text('HTML Parsing Demo')),
body: Center(
child: ElevatedButton(
onPressed: () async {
String htmlContent = await fetchHtml();
print(htmlContent);
},
child: Text('Fetch HTML'),
),
),
);
}
}

3.2 解释
使用 http.get 方法获取指定 URL 的 HTML 内容。
如果请求成功(状态码为 200),则返回 HTML 数据;否则抛出异常。

  1. 解析 HTML 数据
    获取 HTML 数据后,下一步是解析它。使用 html 库可以轻松实现这一点。

4.1 解析 HTML 示例
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'package:html/parser.dart' as html_parser;

void main() {
runApp(MyApp());
}

class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'HTML Parsing Demo',
home: HomeScreen(),
);
}
}

class HomeScreen extends StatelessWidget {
Future> fetchHtmlAndParse() async {
final response = await http.get(Uri.parse('https://example.com'));

if (response.statusCode == 200) {
  // 解析 HTML
  var document = html_parser.parse(response.body);
  // 查找特定的元素,例如获取所有的链接
  var links = document.getElementsByTagName('a');
  return links.map((link) => link.attributes['href']).toList();
} else {
  throw Exception('Failed to load HTML');
}

}

@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text('HTML Parsing Demo')),
body: Center(
child: ElevatedButton(
onPressed: () async {
List links = await fetchHtmlAndParse();
print(links); // 打印所有链接
},
child: Text('Fetch and Parse HTML'),
),
),
);
}
}

4.2 解释
使用 html_parser.parse 方法解析获取的 HTML 内容。
通过 document.getElementsByTagName('a') 获取所有的链接元素,提取它们的 href 属性。

  1. 显示解析结果
    解析出数据后,可以将其在 Flutter UI 中显示出来。例如,我们可以使用 ListView 来显示获取的链接列表。

5.1 显示链接的示例
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'package:html/parser.dart' as html_parser;

void main() {
runApp(MyApp());
}

class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'HTML Parsing Demo',
home: HomeScreen(),
);
}
}

class HomeScreen extends StatefulWidget {
@override
_HomeScreenState createState() => _HomeScreenState();
}

class _HomeScreenState extends State {
Future> fetchHtmlAndParse() async {
final response = await http.get(Uri.parse('https://example.com'));

if (response.statusCode == 200) {
  var document = html_parser.parse(response.body);
  var links = document.getElementsByTagName('a');
  return links.map((link) => link.attributes['href']).toList();
} else {
  throw Exception('Failed to load HTML');
}

}

@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text('HTML Parsing Demo')),
body: FutureBuilder>(
future: fetchHtmlAndParse(),
builder: (context, snapshot) {
if (snapshot.connectionState == ConnectionState.waiting) {
return Center(child: CircularProgressIndicator());
} else if (snapshot.hasError) {
return Center(child: Text('Error: ${snapshot.error}'));
} else {
final links = snapshot.data ?? [];
return ListView.builder(
itemCount: links.length,
itemBuilder: (context, index) {
return ListTile(
title: Text(links[index] ?? 'No link'),
);
},
);
}
},
),
);
}
}

5.2 解释
使用 FutureBuilder 来异步处理获取和解析 HTML 数据。
根据不同的 ConnectionState 显示加载指示器、错误信息或链接列表。
写在最后
在 Flutter 中解析后端返回的 HTML 数据是一个简单而强大的功能。通过使用 http 和 html 库,我们可以轻松获取和解析 HTML 内容,并在 UI 中显示这些信息。无论是为了数据提取还是用户界面构建,理解如何处理 HTML 数据都将为你的 Flutter 应用提供更多的可能性。

希望这篇博客对你有所帮助,欢迎评论与讨论!
————————————————

                        版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/lbcyllqj/article/details/143223577

目录
相关文章
|
2月前
|
监控 JavaScript 编译器
从“天书”到源码:HarmonyOS NEXT 崩溃堆栈解析实战指南
本文详解如何利用 hiAppEvent 监控并获取 sourcemap、debug so 等核心产物,剖析了 hstack 工具如何将混淆的 Native 与 ArkTS 堆栈还原为源码,助力开发者掌握异常分析方法,提升应用稳定性。
432 42
|
3月前
|
开发者 容器
鸿蒙应用开发从入门到实战(十四):ArkUI组件Column&Row&线性布局
ArkUI提供了丰富的系统组件,用于制作鸿蒙原生应用APP的UI,本文主要讲解Column和Row组件的使用以及线性布局的方法。
310 12
|
3月前
|
API 数据处理
鸿蒙应用开发从入门到实战(十三):ArkUI组件Slider&Progress
ArkUI提供了丰富的系统组件,用于制作鸿蒙原生应用APP的UI,本文主要讲解滑块Slider和进度条Progress组件的使用。
192 1
|
3月前
|
JavaScript 开发者 索引
鸿蒙应用开发从入门到实战(九):ArkTS渲染控制
ArkTS拓展了TypeScript,可以结合ArkUI进行渲染控制,是的界面设计具有可编程性。本文简要描述鸿蒙应用开发中的条件渲染和循环渲染。
186 5
|
2月前
|
移动开发 前端开发 Android开发
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
304 12
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
2月前
|
移动开发 JavaScript 应用服务中间件
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
270 5
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
2月前
|
移动开发 Rust JavaScript
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
633 4
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
3月前
|
数据安全/隐私保护 开发者
鸿蒙应用开发从入门到实战(十一):ArkUI组件Text&TextInput
ArkUI提供了丰富的系统组件,用于制作鸿蒙原生应用APP的UI,本文主要讲解文本组件Text和TextInput的使用。
304 3
|
2月前
|
移动开发 Android开发
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
165 0
|
3月前
鸿蒙应用开发从入门到实战(十六):线性布局案例
ArkUI提供了丰富的系统组件,用于制作鸿蒙原生应用APP的UI,本文通过简单案例演示如何使用Column和Row组件实现线性布局。
175 1

热门文章

最新文章

推荐镜像

更多
  • DNS