Удаление нежелательных символов новой строки при добавлении<p>в CKEditor
При загрузке контента с набором абзацев в CKEditor он заменяет мой <p>
теги с <p>	
Это означает, что редактор преобразует это:
<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;
}