♏ 一款浏览器端的 Markdown 编辑器,支持所见即所得(富文本)、即时渲染(类似 Typora)和分屏预览模式。 https://b3log.org/vditor

Van 70833b330a :bug: preview 6 år sedan
.github 6cb1c89896 :octocat: 添加 GitHub Issue 模板 6 år sedan
__test__ b566763c41 :art: fix #25 6 år sedan
demo 08ea0b2569 :art: fix #27 6 år sedan
src 70833b330a :bug: preview 6 år sedan
.gitignore e0069a1bd5 :art: #15 6 år sedan
CHANGELOG.md 70833b330a :bug: preview 6 år sedan
CODE_OF_CONDUCT.md 5338b49361 :octocat: 贡献者公约 6 år sedan
CONTRIBUTING.md db919e16aa :octocat: 贡献指南 6 år sedan
LICENSE c9f1218077 :tada: 6 år sedan
PULL_REQUEST_TEMPLATE.md a1b0c7e71e :octocat: PR 模板 6 år sedan
README.md 9e93845fd1 :art: fix #29 6 år sedan
jest.config.js e0069a1bd5 :art: #15 6 år sedan
package-lock.json 08ea0b2569 :art: fix #27 6 år sedan
package.json 70833b330a :bug: preview 6 år sedan
tsconfig.json 0eafc9cb25 :art: #15 6 år sedan
tslint.json 617f8261b5 :art: fix #14 6 år sedan
webpack.config.js 70833b330a :bug: preview 6 år sedan
webpack.dev.js 65d4a3e308 :recycle: demo -> dev 6 år sedan
webpack.start.js 2ab77e0bdb :art: preview 6 år sedan

README.md

Vditor
下一代的 Markdown 编辑器,为未来而构建

简介

Vditor 是一款浏览器端的 Markdown 编辑器,使用 TypeScript 实现。

背景

太长不看。
我们在开发 [Sym](https://github.com/b3log/symphony) 的初期是直接使用 WYSIWYG 富文本编辑器的。那时候基于 HTML 的编辑器非常流行,项目中引用起来也很方便,也符合用户当时的使用习惯。 后来,Markdown 的崛起逐步改变了大家的排版方式。再加上我们其他几个项目都是面向程序员用户的,所以迁移到 md 上也是大势所趋。我们选择了 [CodeMirror](https://github.com/codemirror/CodeMirror),这是一款优秀的编辑器,它对开发者提供了丰富的编程接口,对各种浏览器的兼容性也比较好。 再后来,随着我们项目业务需求方面的沉淀,使用 CodeMirror 有时候会感到比较“笨重”。比如要实现 @自动完成用户名列表、插入 Emoji、上传文件等就需要比较深入的二次开发,而这些业务需求恰恰是很多项目场景共有且必备的。 终于,我们决定开始在 Sym 中自己实现编辑器。随着几个版本的迭代,Sym 的编辑器也日趋成熟。在我们运营的社区[黑客派](https://hacpai.com)上陆续有人问我们是否能将编辑器单独抽离出来提供给大家使用。与此同时,我们的前端主程 [V](https://hacpai.com/member/Vanessa) 同学对于维护分散在各个项目中的编辑器也感到有点力不从心,外加她最近在学 TypeScript 正好需要练手实践,所以就决定使用 ts 来实现一个全新的浏览器端 md 编辑器。 于是,Vditor 就这样诞生了。

功能

  • 插入原生 Emoji、设置常用表情列表
  • 自定义工具栏按钮、提示、插入文案及快捷键
  • 可使用拖拽、剪切板粘贴上传,显示实时上传进度
  • 支持 CORS 跨域上传
  • 内容保存本地存储,防止意外丢失
  • 录音支持,用户可直接发布语音
  • 粘贴 HTML 自动转换为 Markdown
  • 提供实时预览、滚动同步定位
  • 支持主窗口大小拖拽、字符计数
  • 多主题支持、内置黑白两套
  • 多语言支持、内置中英文
  • 支持主流浏览器和移动端

v

v

案例

  • Sym:一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)平台
  • Solo:一款小而美的博客系统,使用 Java 实现
  • Pipe:一款小而美的博客平台,使用 Go 实现

文档

授权

Vditor 使用 MIT 开源协议。

社区

鸣谢

  • markdown-it:Markdown parser, done right. 100% CommonMark support, extensions, syntax plugins & high speed
  • highlight.js:Javascript syntax highlighter
  • Turndown:🛏 An HTML to Markdown converter written in JavaScript
  • mermaid:Generation of diagram and flowchart from text in a similar manner as markdown