Flowmix/Docx 多模态文档编辑器:V1.3.5版本,全面升级

嗨, 大家好, 我是徐小夕.

最近一直在研究多模态文档引擎, 最近2周对 flowmix/docx文档编辑器又进行了一波功能迭代, 在迭代的过程中也学到很多新的技术, 接下来就和大家一起分享一下, 如果你恰好也在研究类似的产品, 相信会有很多收获.

先说一下1.3.5版本迭代的内容:

  • 编辑器支持AI侧边栏, 可以轻松集成各种AI模型实现内容生成
  • 文档支持划词评论功能
  • 文档支持一键导入Docx文件
  • 支持实时获取当前光标在文档中的位置
  • 优化文档元素插入文档的顺序
  • 新增高级思维导图组件
  • 内联工具条UI优化

后面还会持续迭代更多功能, 比如多人协同 , 一键生成PPT等, 如果大家有好的建议也可以随时在评论区反馈.

最新版Demo演示

接下来我会具体介绍一下更新的功能和技术实现, 给大家一个参考.

演示地址: 在线演示

1. 编辑器支持AI侧边栏

编辑器之前虽然支持了AI问答组件, 但是为了更好的挖掘文的价值, 我集成了AI侧边栏, 大家可以轻松集成市面上的AI大模型, 来实现AI辅助创作.

我们可以轻松的点击右下角的AI按钮, 打开侧边栏和AI对话:

对话组件我采用的是开源的方案 @ant-design/pro-chat , 大家有其他好的插件也可以分享一下哈~

2. 文档支持划词评论功能

划词评论我在之前的文章中有详细的分析, 感兴趣的可以参考一下:

市面上大多数文档编辑器的【划线评论】功能,是如何实现的?

3. 文档支持一键导入Docx文件

文档一键导入docx文件功能可以高效的帮助我们解析docx的内容, 并在flowmix/docx中快速编辑. 接下来给大家看看原始的word文件:

在第一个版本中其实也实现了docx文件的导入, 但是之前对图片, 表格这些docx特有的格式无法支持, 最近研究出来了一个方案, 可以很好的支持docx文件中的表格, 图片等, 并一键转化为flowmix/docx 中支持的数据结构 .

在实现Docx解析方案中我采用了DOMParser API, 这里我给大家介绍一下这个兼容性良好且功能强大的浏览器API.

DOMParser 可以将存储在字符串中的 XML 或 HTML 源代码解析为一个 DOM Document。

我的实现思路是将 Docx 文件解析为 html 字符串, 在基于DOMParser 将html 字符串转化为Dom, 最后对Dom进行分割, 输出 flowmix/docx 支持的json结构.

将 html 字符串转化为 dom 的案例如下:

ini 复制代码
const parser = new DOMParser()
const doc = parser.parseFromString(html, 'text/html')

这样, 我们就能通过节点遍历的方式一键将dom转化为json结构了:

目前 flowmix/docx 已经支持解析的docx格式有:

  • 标题(h1-h6)
  • 文本段落(p)
  • 序号(ul, lo)
  • 图片
  • 表格

后续还会支持更多docx元素, 大家感兴趣的可以参考一下这个方案.

4. 支持实时获取当前光标在文档中的位置

实时获取光标位置的方案主要是为了实现多人协同的光标位置确认, 这里我也基本实现了. 主要是用到了 window.getSelection API, 后续我会详细和大家分享它的应用场景. 实现代码如下:

go 复制代码
const saveSelection = () => {
        const selection = window.getSelection()
        if (selection && selection.rangeCount > 0) {
            const range = selection.getRangeAt(0)
            return {
            anchorNode: range.startContainer,
            anchorOffset: range.startOffset,
            focusNode: range.endContainer,
            focusOffset: range.endOffset
            }
        }
        return null    }

5. 优化文档元素插入文档的顺序

这个问题主要是为了解决文档编辑器当失去焦点时, 仍能争取插入到文档光标最近停留的位置. 之前一直用了"比较笨"的方案, 最近研究了一下,终于用 window.getSelection 实现了.(其实也是用的上述获取光标位置的方式实现的)

6. 新增高级思维导图组件

思维导图的实现方式我也在之前文章中有详细的分享, 大家感兴趣可以参考我之前的文章.

7. 内联工具条UI优化

内联工具条我最近对样式做了进一步统一和优化.

后续规划

最近我们也在花时间做一款文档管理类Saas系统, 底层基于Flowmix/Docx 多模态文档引擎, 这里简单和大家分享一下:

每个月我们都会根据用户的需求和规划的迭代计划持续迭代.

后面的一些规划:

这个月除了会上线文档Saas版1.0之外, 在下个月带给大家更强大的编辑器体验:

  • 支持文档图层面板
  • 支持高级可视化组件
  • 支持文档AI工作流
  • 文档支持演示模式
  • 支持多人协同编辑
  • 支持一键生成PPT

当然从体验上来讲, 文档还有很多优化的空间, 这块我们会持续优化和迭代, 并结合业界最佳体验实践, 将文档搭建能力发挥出最大的价值.

如果你有好的想法和建议, 也欢迎随时留言区交流讨论~

演示地址: 在线演示

相关推荐
困顿小狗23 分钟前
vue2 项目webpack 4升5
前端·webpack
sleeppingfrog25 分钟前
vue3中自定义组件的双向绑定
前端·javascript·vue.js
Domain-zhuo1 小时前
uniapp 应用的生命周期、页面的生命周期、组件的生命周期
前端·javascript·vue.js·前端框架·uni-app·html·ecmascript
旅行中的伊蕾娜1 小时前
uniapp炫酷导航按钮及轮播指示器组件
前端·javascript·vue.js·微信小程序·uni-app
Liberty_yes1 小时前
uniapp navigateTo、redirectTo、reLaunch等页面路由跳转方法的区别
前端·uni-app
cy玩具1 小时前
Vuex在uniapp中的使用
开发语言·javascript·ecmascript
TWenYuan1 小时前
vue响应式数据-修改对象的属性值,视图不更新
前端·javascript·vue.js
振华OPPO1 小时前
VS Code使用NPM脚本启动Vue程序
前端·vue.js·vscode·npm·node.js·vue
乐茵安全2 小时前
基于python对pdf文件进行加密等操作
java·前端·python
超爱吃士力架2 小时前
设计模式五大基本原则
前端·后端·设计模式