自学内容网 自学内容网

【element-tiptap】如何将编辑器初始化为全屏显示?

源码地址:
https://github.com/Leecason/element-tiptap
我们在学习一个项目的代码的时候,最好的学习方式就是带着问题学习。就像题目的这个小问题,今天就一起来探索这一课题吧!
首先看下项目启动后的页面
在这里插入图片描述
这个小符号明显就是控制编辑器缩放的。
当前的路由是这个 demos/views/Simple.vue
其中有一个 Fullscreen 配置项,看名字咱们就能看出来是缩放控制
我们点进去看一下它的定义

import type { Editor } from '@tiptap/core';
import { Extension } from '@tiptap/core';
import FullscreenCommandButton from '@/components/MenuCommands/FullscreenCommandButton.vue';

const Fullscreen = Extension.create({
  name: 'fullscreen',

  addOptions() {
    return {
      ...this.parent?.(),
      button({ editor }: { editor: Editor }) {
        return {
          component: FullscreenCommandButton,
        };
      },
    };
  },
});

export default Fullscreen;

它是使用了tiptap 提供的 Extension.create 方法,创建出来的扩展,对应的组件呢,就是 FullscreenCommandButton。这个组件的定义稍微有点长,主要看控制缩放的属性是怎么来的

const isFullscreen = inject('isFullscreen', false);
const toggleFullscreen = inject('toggleFullscreen');

可以看到,这个属性是通过 inject 注入的,inject 是 Vue3 中,接收祖先组件数据的方法,发出数据的祖先组件需要使用 provide 发出数据。那么我们就在全局搜一下 isFullscreen 属性还在哪里出现好了
就是在 src/components/ElementTiptap.vue 里面

// provide定义子组件可以访问的数据
provide('isFullscreen', isFullscreen);
provide('toggleFullscreen', toggleFullscreen);

那么我们只需要,把 isFullscreen 的默认值改为 true,即可实现编辑器初始化就显示全屏效果啦

const isFullscreen = ref(true);

在这里插入图片描述


原文地址:https://blog.csdn.net/weixin_45855469/article/details/142787444

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!