flutter 富文本思考

https://flutter.cn/docs/get-started/install/windows

https://pub-web.flutter-io.cn/packages/flutter_widget_from_html

1 如何保证多渠道内容

方案一: 直接使用基本的 html 格式来存储 特殊信息使用 自定义属性来做区分 自定义属性来做信息存储

app 端使用 flutter_widget_from_html 将html 转换成 原生组件

web端 css 属性选择器进行 css 注入

需要存储@的相关信息

实现思路:

网页做输入,重写富文本编辑器

优点: 只需要解析特定标签的属性值 为特定组件

缺点:

html 不同解析器 可能解析的样式不一样

方案二: 将所有信息使用数组来存储 ,数组内存储不同节点的信息,然后按照信息的类别 逐条进行信息拼接

app 端 和 web 按照同一套解析规则 来解析

方案三:如果只有图文 链接 @ # 等特殊格式的内容, 存储时 图片单独字段 文字单独字段,@信息单独字段 #信息单独字段。渲染时 @ 和 # 按照格式进行 样式渲染。点击触发时再查询节点信息 做处理。

4、技术思路

通过分析业内的主流实现,@人功能的技术实现思路大致如下:

1)监听用户输入,匹配用户以@开头的文字;

2)调用搜索弹窗,展示搜索出来的用户列表;

3)监听上、下、回车键控制列表选择,监听ESC键关闭搜索弹窗;

4)选择需要@的用户,把对应的HTML文本替换到原文本上,在HTML文本上添加用户的元数据。

https://www.sohu.com/a/506642053_100038287#google_vignette

需要考虑的问题

1 如@ # 特定内容的输入

2 不同平台的 如何解析 @ # 等的特殊内容

3 实现的难点 和 花费的时间

1 网页做内容输入 =》富文本 难点

https://react-mentions.vercel.app/

https://github.com/codex-team/editor.js

editorjs富文本编辑器 ==》实现插件的形式

https://editorjs.io/

wangeditor 富文本编辑器 ==》调用api 新增功能

https://www.wangeditor.com/v5/for-frame.html#demo-2

2 app 多内容输入 =》 难点

不同端多内容解析

相关推荐
程序员老刘5 小时前
跨平台开发地图:客户端技术选型指南 | 2025年12月
flutter·客户端
一名普通的程序员5 小时前
使用 Flutter Pay 插件实现 Apple Pay 和 Google Pay 的完整指南
flutter
麦客奥德彪6 小时前
Flutter riverpod 对应Android开发概念理解
flutter
tangweiguo030519877 小时前
Kotlin vs Dart vs Swift:语法对比全解
flutter
feelingHy7 小时前
GetX 状态管理实践
flutter
tangweiguo030519878 小时前
Flutter多品牌应用架构实战:从配置驱动到编译部署的完整解决方案
flutter
Bryce李小白9 小时前
FlutterBoost适配Flutter3.38.4版本生成补丁包
flutter
tangweiguo030519879 小时前
Flutter Packages 设计与实践:构建可维护的模块化应用
flutter
小a杰.10 小时前
Flutter 的编译技术核心
flutter
hudawei99611 小时前
flutter setState(() { … }) 作用
flutter