深入浅出 Quill 系列之实践篇1:如何将龙插入到编辑器中?

引言

这是深入浅出 Quill 系列的第5篇。

之前在掘金看到一篇文章:《产品经理:你能不能用div给我画条龙? 》

于是突发奇想:

能否把这条龙插入到富文本编辑器中呢?

1 在富文本编辑器中插入自定义内容

之前给大家分享了如何在 Quill 中插入自定义的内容,我们一起来回顾下:

  • 第一步:自定义工具栏按钮
  • 第二步:自定义 Blot 内容
  • 第三步:在 Quill 注册自定义 Blot
  • 第四步:调用 Quill 的 API 插入自定义内容

我们试着按照这个步骤来将龙插入到编辑器中。

2 第一步:自定义工具栏按钮

这个非常简单:

ts 复制代码
    const TOOLBAR_CONFIG = [
      [{ header: ['1', '2', '3', false] }],
      ['bold', 'italic', 'underline', 'link'],
      [{ list: 'ordered' }, { list: 'bullet' }],
      ['clean'],
      ['card', 'divider', 'emoji', 'file', 'tag'],
      ['dragon'], // 新增的
    ];

自定义工具栏按钮图标:

ts 复制代码
    const dragonIcon = `<svg>...</svg>`;
    const icons = Quill.import('ui/icons');
    icons.dragon = dragonIcon;

增加工具栏按钮事件:

ts 复制代码
    const quill = new Quill('#editor', {
      theme: 'snow',
      modules: {
        toolbar: {
          container: TOOLBAR_CONFIG,
          handlers: {
            ...
            // 增加一个空的事件
            dragon(value): void {
              console.log('dragon~~');
            },
          },
        }
      },
    });

3 第二步:自定义 Blot 内容(核心)

之前的分享提到:

Quill 中的 Blot 就是一个普通的 ES6 Class

因此我们需要编写一个类。

dragon.ts

ts 复制代码
    import Quill from 'quill';

    const BlockEmbed = Quill.import('blots/block/embed');

    class DragonBlot extends BlockEmbed {
      static blotName = 'dragon';
      static tagName = 'canvas';

      static create(value): any {
        const node = super.create(value);
        const { id, width, height } = value;

        node.setAttribute('id', id || DragonBlot.blotName);
        if (width !== undefined) {
          node.setAttribute('width', width);
        }
        if (height !== undefined) {
          node.setAttribute('height', height);
        }

        // 绘制龙的逻辑,参考大帅老师的文章:https://juejin.cn/post/6963476650356916254
        new Dragon(node);
        
        return node;
      }
    }

    export default DragonBlot;

3.1 绘制龙

绘制龙的逻辑参考大帅老师的文章,这里就不贴代码了,大帅老师的文章里有源码,直接拿来用就可以:

产品经理:你能不能用div给我画条龙?

需要注意的是大帅老师文章里的龙图片背景不是纯黑的,需要换一张纯黑的图片。

4 第三步:在 Quill 注册自定义 Blot

有了 DragonBlot,还需要将其注册到 Quill 中才能使用:

ts 复制代码
    import DragonBlot from './formats/dragon';
    Quill.register('formats/dragon', DragonBlot);

5 第四步:调用 Quill 的 API 插入自定义内容

最后一步,见证奇迹的时刻到了!

ts 复制代码
    const quill = new Quill('#editor', {
      theme: 'snow',
      modules: {
        toolbar: {
          container: TOOLBAR_CONFIG,
          handlers: {
            ...
            dragon(value): void {
              console.log('dragon~~');
              const index = this.quill.getSelection().index;
              // 插入自定义内容
              this.quill.insertEmbed(index, 'dragon', {
                id: 'canvas-dragon',
              });
            },
          },
        }
      },
    });

效果图:

总结

本文是一个 Quill 的综合案例,从自定义工具栏按钮,到自定义 Blot 编辑器内容格式,再到调用 Quill 实例的 insertEmbed 方法,完成在富文本编辑器中插入由 Canvas 绘制的龙这种复杂的自定义内容。

下一期我会带大家在富文本编辑器中插入贪吃蛇游戏,巩固在 Quill 中自定义内容的知识,大家也可以提前思考下如何实现。

相关推荐
高山上有一只小老虎11 分钟前
SpringBoot项目集成thymeleaf实现web
前端·spring boot·后端
求梦82019 分钟前
前端八股文【CSS核心面试题库】
前端·css·面试
算法小菜鸟成长心得20 分钟前
记录自己第一次将React 编写的前端部署到服务器,实现外网访问
服务器·前端·react.js
怒放的生命19911 小时前
pnpm + Monorepo 使用教程(集成 Vue 3 项目)
前端·vue.js·pnpm·monorepo·前端工程化
佛系打工仔6 小时前
绘制K线第二章:背景网格绘制
android·前端·架构
明天好,会的8 小时前
分形生成实验(五):人机协同破局--30万token揭示Actix-web状态管理的微妙边界
运维·服务器·前端
猫头虎8 小时前
如何在浏览器里体验 Windows在线模拟器:2026最新在线windows模拟器资源合集与技术揭秘
运维·网络·windows·系统架构·开源·运维开发·开源软件
C_心欲无痕8 小时前
nginx - alias 和 root 的区别详解
运维·前端·nginx
修己xj10 小时前
从“死了么”到“活着记”:用Gmeek在数字世界留下思想印记
开源