0

我怎样才能让内部编辑器部分(用细蓝线突出显示)达到全高。这是由tiptap 编辑器创建的内部元素:

<div contenteditable="true" tabindex="0" class="ProseMirror" spellcheck="false"> Editable content goes here./div>

更新:

我在渲染输出中手动添加了类('col' 和 'column'),现在它按我想要的方式工作。有没有办法做到这一点而不必触及元素的类属性?

<div contenteditable="true" tabindex="0" class="ProseMirror col column" spellcheck="false"> Content Here </div>

这是我在 quasar 示例应用程序中使用的组件代码。我在编辑器周围的 div 中尝试了无数不同的类变体。我所做的一切似乎都不会影响上面生成的“contenteditable”div 容器。

<template>
  <q-page class="column justify-start">
      <div class="column col absolute-full bg-secondary">
        <div class="col column editor">
          <editor-menu-bar :editor="editor" v-slot="{ commands, isActive }">
            <div class="menubar">

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.bold() }"
                @click="commands.bold"
              >
                <icon name="bold" />
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.italic() }"
                @click="commands.italic"
              >
                <icon name="italic" />
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.strike() }"
                @click="commands.strike"
              >
                <icon name="strike" />
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.underline() }"
                @click="commands.underline"
              >
                <icon name="underline" />
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.code() }"
                @click="commands.code"
              >
                <icon name="code" />
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.paragraph() }"
                @click="commands.paragraph"
              >
                <icon name="paragraph" />
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.heading({ level: 1 }) }"
                @click="commands.heading({ level: 1 })"
              >
                H1
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.heading({ level: 2 }) }"
                @click="commands.heading({ level: 2 })"
              >
                H2
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.heading({ level: 3 }) }"
                @click="commands.heading({ level: 3 })"
              >
                H3
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.bullet_list() }"
                @click="commands.bullet_list"
              >
                <icon name="ul" />
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.ordered_list() }"
                @click="commands.ordered_list"
              >
                <icon name="ol" />
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.blockquote() }"
                @click="commands.blockquote"
              >
                <icon name="quote" />
              </button>

              <button
                class="menubar__button"
                :class="{ 'is-active': isActive.code_block() }"
                @click="commands.code_block"
              >
                <icon name="code" />
              </button>

              <button
                class="menubar__button"
                @click="commands.horizontal_rule"
              >
                <icon name="hr" />
              </button>

              <button
                class="menubar__button"
                @click="commands.undo"
              >
                <icon name="undo" />
              </button>

              <button
                class="menubar__button"
                @click="commands.redo"
              >
                <icon name="redo" />
              </button>

            </div>
          </editor-menu-bar>
          <editor-content class="col column editor__content" :editor="editor" />
        </div>
      </div>
  </q-page>
</template>

<script>
import Icon from 'components/Icon'
import { Editor, EditorContent, EditorMenuBar } from 'tiptap'
import {
  Blockquote,
  CodeBlock,
  HardBreak,
  Heading,
  HorizontalRule,
  OrderedList,
  BulletList,
  ListItem,
  TodoItem,
  TodoList,
  Bold,
  Code,
  Italic,
  Link,
  Strike,
  Underline,
  History
} from 'tiptap-extensions'

export default {
  components: {
    EditorContent,
    EditorMenuBar,
    Icon
  },
  data () {
    return {
      editor: new Editor({
        extensions: [
          new Blockquote(),
          new BulletList(),
          new CodeBlock(),
          new HardBreak(),
          new Heading({ levels: [1, 2, 3] }),
          new HorizontalRule(),
          new ListItem(),
          new OrderedList(),
          new TodoItem(),
          new TodoList(),
          new Link(),
          new Bold(),
          new Code(),
          new Italic(),
          new Strike(),
          new Underline(),
          new History()
        ],
        content: `
          <h2>
            Hi there,
          </h2>
          <p>
            this is a very <em>basic</em> example of tiptap.
          </p>
          <pre><code>body { display: none; }</code></pre>
          <ul>
            <li>
              A regular list
            </li>
            <li>
              With regular items
            </li>
          </ul>
          <blockquote>
            It's amazing 
            <br />
            – mom
          </blockquote>
        `
      })
    }
  },
  beforeDestroy () {
    this.editor.destroy()
  }
}
</script>

<style>
</style>

我一直在学习 Vue.js 和 Quasar UI 工具集。我想使用 TIPTAP WYSIWYG 编辑器组件(可在此处获得:https ://github.com/scrumpy/tiptap )。我对他们的示例很好,我可以让组件加载并正常工作。但是对于我的生活,我无法弄清楚如何从一开始就让内部编辑部分(当您单击它时以蓝色勾勒出来)变为“全高”。

我已经尝试了我能想到的一切,并搜索并搜索了某种示例。当您添加内容时,编辑器会很好地扩展(增长),但由于某种原因,我无法让它从全高开始 - 我会注意到该示例也没有说明。

我不做什么?

4

1 回答 1

0

尝试在 css 上写这个

/* remove outline */
.ProseMirror:focus {
  outline: none;
}
/* set */
.ProseMirror {        
  min-height: 100px;
  max-height: 100px;
  overflow: scroll;
}
于 2021-08-06T13:19:48.060 回答