Я вижу несколько причин, почему ваш пример не работает.
- Я почти уверен, что ключ добавляется в текстовую область во время события нажатия клавиши. Это может быть ключом вниз. Но это определенно не событие keyup.
- keyCode, который идет с событием ckeditor, не может быть передан прямо в текстовую область. в нем есть информация о том, нажаты ли клавиши alt, ctrl и shift. Вы должны будете раздеть их сначала. (см. мой пример ниже, где я создаю переменную rawKey)
Возможно, вы также захотите удалить вызов textarea.bind () из обработчика событий. Помещение этого означает, что вы будете привязывать другую копию обработчика событий к текстовой области при каждом нажатии клавиши в кейдиторе. вероятно, не то, что вы хотите.
В любом случае, вот мой образец
function onEditorKeyEvent(event) {
var rawKey = event.data.keyCode & ~(CKEDITOR.SHIFT | CKEDITOR.CTRL | CKEDITOR.ALT);
var eventData =
{
altKey: !!(event.data.keyCode & CKEDITOR.ALT),
ctrlKey: !!(event.data.keyCode & CKEDITOR.CTRL),
shiftKey: !!(event.data.keyCode & CKEDITOR.SHIFT),
keyCode: rawKey,
which: rawKey
};
var myTextbox = $('#myTextBox');
triggerKeyEvents(eventData, myTextbox);
}
function triggerKeyEvents(eventData, elementToTriggerOn)
{
// these key events can generate an extra keyUp event for some reason if they are done in the same thread.
//so we just do them on a different thread :-)
setTimeout(this.callback(function () {
var keydownEvent = jQuery.Event('keydown', eventData);
elementToTriggerOn.trigger(keydownEvent);
if (!keydownEvent.isDefaultPrevented()) {
elementToTriggerOn.trigger(jQuery.Event('keypress', eventData));
}
elementToTriggerOn.trigger(jQuery.Event('keyup', eventData));
}), 1);
}