LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

分享一款基于web的纯JS开源Word文档编辑器canvas-editor

admin
2024年3月9日 14:32 本文热度 762


hi,大家好,最近在研究基于 web 的文档编辑器,在网上调研了很多方案,刚好看到了一款非常有意思的开源编辑器——canvas-editor,它底层基于 canvas 实现,我们使用它可以实现类似于 word文档编辑器类似的效果,同时还支持很多灵活可配置的 API,可以帮助我们定制属于自己的文档编辑平台,如果你刚好也想着手实现,这个项目将非常适合你。

同时,作者是国内大佬,欢迎点赞支持。

好了,话不多说,接下来我们看看它具体的使用和实现效果。

github地址:

https://github.com/Hufe921/canvas-editor

预览地址:

https://hufe.club/canvas-editor

效果展示:

我先展示一下我本地使用 canvas-editor 开发的编辑器效果:

插入表格:

插入公式:

是不是很像在 word 里编写文档的感觉~

功能点介绍

canvas-editor 功能点介绍如下:

  • 富文本操作(撤销、重做、字体、字号、加粗、斜体、上下标、对齐方式、标题、列表.....)
  • 插入元素(表格、图片、链接、代码块、分页符、Math 公式、日期选择器、内容块......)
  • 打印(基于 canvas 转图片、pdf 绘制)
  • 控件(单选、文本、复选框)
  • 右键菜单(内部、自定义)
  • 快捷键(内部、自定义)
  • 文字、元素、控件拖拽
  • 页眉、页脚、页码
  • 页边距
  • 水印
  • 分页

安装 & 使用

  1. 安装依赖
pnpm i @hufe921/canvas-editor --save
  1. 基本使用案例

// dom
<div 
class="canvas-editor"></div>

/
/ js
import Editor from '@hufe921/
canvas-editor'

new Editor(
  document.querySelector('
.canvas-editor'),
  {
    header: [
      {
        value: '
Header',
        rowFlex: RowFlex.CENTER
      }
    ],
    main: [
      {
        value: '
H5-Dooring零代码'
      }
    ],
    footer: [
      {
        value: '
H5-Dooring',
        size: 12
      }
    ]
  },
  {}
)

当然为了使用更全面的功能,我们还可以根据提供的配置来进行更自由的配置,如下:

interface IEditorOption {
  mode?: EditorMode 
// 编辑器模式:编辑、清洁(不显示视觉辅助元素。如:分页符)、只读、表单(仅控件内可编辑)、打印(不显示辅助元素、未书写控件及前后括号)。默认:编辑
  defaultType?: 
string // 默认元素类型。默认:TEXT
  defaultColor?: 
string // 默认字体颜色。默认:#000000
  defaultFont?: 
string // 默认字体。默认:Microsoft YaHei
  defaultSize?: 
number // 默认字号。默认:16
  width?: 
number // 纸张宽度。默认:794
  height?: 
number // 纸张高度。默认:1123
  scale?: 
number // 缩放比例。默认:1
  defaultHyperlinkColor?: 
string // 默认超链接颜色。默认:#0000FF
  header?: IHeader 
// 页眉信息。{top?:number; maxHeightRadio?:MaxHeightRatio;}
  footer?: IFooter 
// 页脚信息。{bottom?:number; maxHeightRadio?:MaxHeightRatio;}
  pageNumber?: IPageNumber 
// 页码信息。{bottom:number; size:number; font:string; color:string; rowFlex:RowFlex; format:string; numberType:NumberType;}
  paperDirection?: PaperDirection 
// 纸张方向:纵向、横向
  inactiveAlpha?: 
number // 正文内容失焦时透明度。默认值:0.6
  historyMaxRecordCount?: 
number // 历史(撤销重做)最大记录次数。默认:100
  contextMenuDisableKeys?: 
string[] // 禁用的右键菜单。默认:[]
  scrollContainerSelector?: 
string // 滚动区域选择器。默认:document
  wordBreak?: WordBreak 
// 单词与标点断行:BREAK_WORD首行不出现标点&单词不拆分、BREAK_ALL按字符宽度撑满后折行。默认:BREAK_WORD
  watermark?: IWatermark 
// 水印信息。{data:string; color?:string; opacity?:number; size?:number; font?:string;}
  control?: IControlOption 
// 控件信息。 {placeholderColor?:string; bracketColor?:string; prefix?:string; postfix?:string;}
  background?: IBackgroundOption 
// 背景配置。{color?:string; image?:string; size?:BackgroundSize; repeat?:BackgroundRepeat;}。默认:{color: '#FFFFFF'}
  
// ...更多配置
}

当然还有很多有意思的api,大家也可以参考它的文档:

最终附上一个完整的demo效果:


该文章在 2024/3/9 14:42:33 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2024 ClickSun All Rights Reserved