Как настроить CKEditor для нескольких экземпляров с разной высотой?

Я хотел бы иметь несколько экземпляров CKEditor на основе одинаковых настроек конфигурации, но с разной высотой. Я пытался настроитьconfig с высотой по умолчанию, настраивая 1-й экземпляр, затем переопределяя высоту & amp; Настройка 2-го экземпляра:

var config = {
    .....
    height:'400'
};

$('#editor1').ckeditor(config);
config.height = '100';
$('#editor2').ckeditor(config);

... но я получаю два экземпляра CKEditor, каждый из которых имеет высоту 100px.

Я также попробовал это:

CKEDITOR.replace('editor2',{
    height: '100'
});

.. Я получил сообщения об ошибке, что экземпляр уже существует. Я искал немного & amp; нашел кого-то в аналогичной ситуации получил совет, что вы должны уничтожить () экземпляр перед replace (), но это кажется слишком сложным для установки другогоinitial рост.

В конце я настроил два разных конфига & amp; скопировано через свойство toolbar_Full:

var config1 = {
    height:'400',
    startupOutlineBlocks:true,
    scayt_autoStartup:true,
    toolbar_Full:[
        { name: 'clipboard', items : [ 'Cut','Copy','Paste','PasteText','PasteFromWord','-','Undo','Redo' ] },
        { name: 'editing', items : [ 'Find','Replace','-' ] },
        { name: 'basicstyles', items : [ 'Bold','Italic','Underline','Strike','Subscript','Superscript','-','RemoveFormat' ] },
        { name: 'paragraph', items : [ 'NumberedList','BulletedList','-','Outdent','Indent','-','Blockquote','-','JustifyLeft','JustifyCenter','JustifyRight','JustifyBlock','-','BidiLtr','BidiRtl' ] },
        '/',
        { name: 'links', items : [ 'Link','Unlink','Anchor' ] },
        { name: 'insert', items : [ 'Image','HorizontalRule' ] },
        { name: 'styles', items : [ 'Styles','Format','Font','FontSize' ] },
        { name: 'colors', items : [ 'TextColor','BGColor' ] },
        { name: 'tools', items : [ 'Maximize', 'ShowBlocks' ] },
        { name: 'document', items : [ 'Source' ] }
    ]
}

var config2 = {
    height:'100',
    startupOutlineBlocks:true,
    scayt_autoStartup:true
};
config2.toolbar_Full = config1.toolbar_Full;

$('#editor1').ckeditor(config1);
$('#editor2').ckeditor(config2);

Есть ли способ лучше? Что-то, чего мне не хватает? Там & APOS; sэтот вопрос но они не опубликовали достаточно, чтобы быть полезными, & amp;это очень похожий вопрос ответ не получен. Спасибо!

Update:

Это похоже на причуду обработки времени / конфигурации CKEditor - конфигурация читается & amp; применяется позже (я полагаю, что после установки структуры DOM редактора), а не тогда, когда редактор создается впервые.

Итак, любые изменения в настройках конфига сделаныimmediately after первый редактор создается с помощью .ckeditor ()actually applied редактором в какой-то момент в следующие несколько миллисекунд. Я утверждаю, что это не нормальное поведение или логическое поведение.

Например, вы можете получить ожидаемое поведение в моем первом примере (переопределивconfig.height свойство после создания первого редактора), чтобы работать путем задержки второго экземпляра CKEditor с помощью setTimeout (). Firefox требовалось ~ 100 мс, IE нужно 1 мс. Wacky & amp; неправильно.

CKEditor должен прочитать параметры конфигурации при первом создании каждого редактора. На данный момент каждый должен обойти эту причуду.

Ответы на вопрос(6)

Ваш ответ на вопрос