CKEditor 4.x:禁止一个标签位于另一个标签内

标签 ckeditor ckeditor4.x

我最近开始使用 CKEditor 4.x,但我希望用户只能使用非常有限的标签集。此外,并非所有标签组合都有用。

我目前只允许这些标签/格式:

<p>, <h3>, <ul>, <ol>, <li>, <strong>, <em> (and maybe some more)

我只需要,列表是为正常风格而不是标题而制作的。但绝对可以在列表元素内创建标题。结果看起来很有趣,但没有用。列表(点或编号)的样式与普通文本相同,但标题文本与标题类似(不同的字体、不同的字体大小、不同的颜色)。

我想禁止这个。我还发现,在某些情况下,CKEditor 还会放置 <p>列表内的标签,我也不想要。我想,这主要是当我将列表内的标题更改回正常状态时,CKEditor 只是将标题标签更改为 <p> .

是否有可能阻止 CKEditor 4 这样做?我看到,甚至还有一张关于 CKEditor 3 类似问题的票证:

http://dev.ckeditor.com/ticket/6849

但是由于 CKEditor 4 似乎是重写,因此该解决方案似乎不适用(已修复为关闭)。

有人知道我该如何防止这种情况发生吗?为了更清楚地说明:这与粘贴文本或源编辑无关,我对编辑器进行了很大限制,并且 Pane 仅包含这些样式和撤消/重做。但是,使用普通命令仍然可以创建这种不需要的样式。

我想要的是:

<h3>A simple headline</h3>
<p>A simple paragraph</p>
<ul>
    <li>First text</li>
    ...
</ul>

想要的是:

<ul>
    <li><p>First text</p></li>
    ...

甚至:

<ul>
    <li><h3>First text</h3></li>
    ...

最佳答案

没有办法轻松实现这一目标。原因是创建此内容的方法有很多。可以粘贴列表,可以在列表项中创建标题,可以在标题上创建列表,也许您可​​以通过删除、拖放等来完成此操作。可以处理所有这些情况并防止创建这些结构,但这需要大量工作。

相反,我认为您可以设置 li>p, li>h3 的样式,使内部 block 在编辑器内不可见(无边距,相同的字体大小)。然后,您还可以在显示该内容的页面上应用这些样式,或者可以在从编辑器检索内容时清理内容。后者可以例如完成这样(参见 editor#toDataFormat event ):

editor.on( 'toDataFormat', function( evt ) {
    var filter = new CKEDITOR.htmlParser.filter( {
        elements: {
            p: function( el ) {
                if ( el.parent && el.parent.name == 'li' ) {
                    delete el.name; // This removes the element and leaves its content.
                }
            }
        }
    } );

    filter.applyTo( evt.data.dataValue );
}, null, 12 );

关于CKEditor 4.x:禁止一个标签位于另一个标签内,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28916595/

相关文章:

javascript - 如何在ckeditor中对一个元素应用多种样式?

javascript - CKEditor 在样式中插入不可编辑的 HTML

Angular 和动态添加的 CKEditors 中断

javascript - 如果文本格式不正确,则在 ckeditor 中格式化 html

javascript - Ckeditor不显示在生产Rails中

php - 防止 PyroCMS 从所见即所得内容中剥离内联样式?

javascript - 使两个编辑器在自动增长时具有相同的大小

position - 如何使内联ckeditor工具栏固定在顶部而不是 float

javascript - 内联 CKEditor 工具栏没有 h2 元素的对齐按钮

javascript - 在 CKEditor 5 中呈现 HTML 页面