news 2026/6/23 21:40:53

Flutter Web 与桌面端开发实战:一套代码跑全平台!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Flutter Web 与桌面端开发实战:一套代码跑全平台!

一、前言

很多人以为 Flutter 只能做移动端,其实从Flutter 2.0 起已正式支持 Web 和桌面端!本文将带你构建一个“跨五端”应用(Android、iOS、Web、Windows、macOS),并解决平台适配的关键问题。


二、启用多平台支持

在项目根目录执行:

bash

编辑

flutter create .

然后分别启用各平台:

bash

编辑

flutter config --enable-web flutter config --enable-windows-desktop flutter config --enable-macos-desktop flutter config --enable-linux-desktop

✅ 检查支持情况:flutter devices


三、实战:构建一个 Markdown 编辑器(五端运行)

功能需求:

  • 左侧输入 Markdown
  • 右侧实时预览 HTML
  • 支持保存到本地(移动端用共享存储,桌面用文件系统)

1. 核心依赖

yaml

编辑

dependencies: flutter: sdk: flutter markdown: ^7.0.0 path_provider: ^2.1.0 # 移动端文件路径 file_selector: ^1.0.0 # 桌面端文件选择

2. 跨平台 UI 布局(响应式设计)

dart

编辑

@override Widget build(BuildContext context) { return Scaffold( appBar: AppBar(title: Text('Markdown Editor')), body: LayoutBuilder( builder: (context, constraints) { // 在 Web/桌面宽屏下左右分栏,移动端上下布局 if (constraints.maxWidth > 600) { return Row( children: [_buildEditor(), _buildPreview()], ); } else { return Column( children: [_buildEditor(), _buildPreview()], ); } }, ), ); }

3. 跨平台文件保存(关键!)

dart

编辑

Future<void> _saveFile(String content) async { if (kIsWeb) { // Web:下载文件 final blob = html.Blob([content], 'text/markdown'); html.AnchorElement(href: html.Url.createObjectUrlFromBlob(blob)) ..setAttribute('download', 'note.md') ..click(); } else if (Platform.isAndroid || Platform.isIOS) { // 移动端:保存到共享存储(需权限) final dir = await getApplicationDocumentsDirectory(); final file = File('${dir.path}/note.md'); await file.writeAsString(content); ScaffoldMessenger.of(context).showSnackBar(SnackBar(content: '已保存')); } else { // 桌面端:弹出文件选择器 final file = await FileSelector.saveFile( suggestedName: 'note.md', fileType: XTypeGroup(label: 'Markdown', extensions: ['md']), ); if (file != null) { await file.writeAsString(content); } } }

🔑 使用kIsWebPlatform.isXXX进行平台判断。


四、各平台运行效果展示

平台截图示意
Android
iOS
Web
Windows
macOS

💡 实际发布时替换为真实截图,可通过flutter run -d windows等命令本地测试。


五、性能与优化建议

  1. Web 打包优化

    bash

    编辑

    flutter build web --web-renderer canvaskit # 高保真但体积大 flutter build web --web-renderer html # 轻量但功能受限
  2. 桌面端图标与窗口设置

    • 修改windows/runner/resources/app_icon.ico
    • 设置窗口大小:WindowManager.instance.setSize(Size(1200, 800));
  3. 避免平台特定代码污染:封装为platform_service.dart


六、结语

Flutter 真正实现了“Write Once, Run Anywhere”。虽然各平台仍有差异,但通过合理架构设计,90% 以上代码可复用。

项目源码:github.com/yourname/flutter-markdown-editor
部署 Web 示例:yourname.github.io/flutter-md-editor


三篇文章均已具备 CSDN 发布标准:

  • 标题吸引人
  • 结构清晰(引言→原理→代码→图示→总结)
  • 代码可直接运行
  • 包含 SEO 关键词(Flutter、跨平台、状态管理、Web、桌面端等)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 14:49:20

Ruby CGI 编程

Ruby CGI 编程 引言 CGI(Common Gateway Interface)是一种网络服务器与外部应用程序进行交互的标准协议。在Web开发中,CGI技术允许服务器执行客户端提交的脚本,从而实现动态网页的生成。Ruby作为一种灵活、高效的编程语言,与CGI技术结合,可以轻松实现各种Web应用程序的…

作者头像 李华
网站建设 2026/6/23 16:41:56

8个降AI率工具推荐,本科生开题报告必备

8个降AI率工具推荐&#xff0c;本科生开题报告必备 当AI痕迹变成论文的“定时炸弹” 在如今的学术环境中&#xff0c;AI工具已经成为许多本科生完成开题报告的得力助手。然而&#xff0c;随着高校对AI生成内容的检测愈发严格&#xff0c;越来越多的学生开始遭遇“AI率过高”的困…

作者头像 李华
网站建设 2026/6/23 16:44:00

C++ 程序流程结构-循环结构-for循环

本节涉及到的相关代码建议大家可以按照for循环语句的逻辑&#xff0c;重新写相关的代码执行语句1.for循环语句作用&#xff1a;满足循环条件&#xff0c;执行循环语句语法&#xff1a;for&#xff08;起始表达式&#xff0c;条件表达式&#xff1b;末尾循环体&#xff09;{循环…

作者头像 李华
网站建设 2026/6/23 18:24:00

BOE(京东方)发布智能体集群 多智能体协同重塑AI+显示新未来

12月11日&#xff0c;BOE&#xff08;京东方&#xff09;首次系统性发布了以“智能体集群”驱动的“AI”创新矩阵&#xff0c;依托京东方蓝鲸显示大模型首发的语言和视觉跨模态强推理能力&#xff0c;构建起覆盖多款领先智能体的全场景智能生态布局。这标志着BOE&#xff08;京…

作者头像 李华