Удаление нежелательных символов новой строки при добавлении<p>в CKEditor

При загрузке контента с набором абзацев в CKEditor он заменяет мой <p> теги с <p>&#x9;

Это означает, что редактор преобразует это:

<p>paragraph 1</p>
<p>paragraph 2</p>
<p>paragraph 3</p>

в то, что заканчивается так:

<p>
   paragraph 1</p>
<p>
   paragraph 2</p>
<p>
   paragraph 3</p>

Как это исправить, чтобы CKEditor не добавлял лишние символы новой строки, когда видит теги абзаца?

5 ответов

Решение

Добавьте эту строку в файл конфигурации ckeditor.js:

n.setRules('p',{indent:false,breakAfterOpen:false});

Больше о форматировании HTML Writer можно найти в Руководстве для разработчиков: Форматирование выходных документов в CKSource Docs.

В другом месте (мои извинения за то, что я не запомнил, откуда я это взял), я нашел код, который исправит эту проблему для всех тегов уровня блока. Для моего проекта дополнительные строки были проблемой из-за вывода в XML и импорта в другие приложения как CDATA.

Итак, в моем файле ckeditor_config.js после функции CKEDITOR.editorConfig я добавил следующее:

CKEDITOR.on('instanceReady', function( ev ) {
  var blockTags = ['div','h1','h2','h3','h4','h5','h6','p','pre','li','blockquote','ul','ol',
  'table','thead','tbody','tfoot','td','th',];

  for (var i = 0; i < blockTags.length; i++)
  {
     ev.editor.dataProcessor.writer.setRules( blockTags[i], {
        indent : false,
        breakBeforeOpen : true,
        breakAfterOpen : false,
        breakBeforeClose : false,
        breakAfterClose : true
     });
  }
});

Некоторые из этих элементов могут не нуждаться в этом лечении; очевидно, массив blockTags может быть легко отредактирован в соответствии с вашими потребностями.

Я считаю, что есть настройка для форматирования кода, или авто-отступ или что-то в этом роде. Он был призван сделать исходный код более читабельным. Я полагаю, что эффективность открыта для мнения.

Если вы похожи на меня и хотели бы сделать это на уровне экземпляра и не хотите прикасаться к файлам конфигурации, чтобы их было легко обновить / обновить. Тогда вот другое решение.

CKEDITOR.replace( 'editor1',
{
    on :
    {
        instanceReady : function( ev )
        {
            // Output paragraphs as <p>Text</p>.
            this.dataProcessor.writer.setRules( 'p',
                {
                    indent : false,
                    breakBeforeOpen : true,
                    breakAfterOpen : false,
                    breakBeforeClose : false,
                    breakAfterClose : true
                });
        }
    }
});

Ссылка: Форматирование вывода

Лучшее решение, которое будет работать как шарм:

отредактируйте файл contents.css и настройку стиля для абзацев, например

 p {
     margin-top:0px;
     margin-bottom:5px;
 }
Другие вопросы по тегам