При использовании Handsontable как заставить выбранную ячейку в режим редактирования?
Handsontable предоставляет некоторые хорошие крючки для того, когда выбрана ячейка, но я не могу понять, как заставить ее позволить мне принудительно перевести ячейку в режим редактирования, когда она была выбрана.
Я могу обнаружить выбор ячейки следующим образом:
Handsontable.PluginHooks.add( 'afterSelection', function( row, column ) {
var current_td = this.getCell( row, column );
});
и оттуда я могу даже получить элемент, который был выбран. Но оттуда я не могу вызвать ячейку в режим редактирования (где внутри нее есть активно выбранное поле textarea). Это нормально срабатывает от двойного щелчка. Делать очевидное, похоже, не работает:
Handsontable.PluginHooks.add( 'afterSelection', function( row, column ) {
var current_td = this.getCell( row, column );
$(current_td).dblclick();
});
кто - нибудь еще когда-либо делал это или думал о том, как я могу заставить его работать?
3 ответов
для тех, кто интересуется этим вопросом, теперь есть лучший программируемый способ достичь того же результата.
this.selectCell(row, col);
this.getActiveEditor().beginEditing();
выбирается (row, col)
ячейка и переходит в режим редактирования (т. е. так же, как двойной щелчок или нажатие F2/Enter).
и, кажется, я сам ответил на свой вопрос:
Handsontable.PluginHooks.add( 'afterSelectionEnd', function() {
f2_event = $.Event( 'keydown', { keyCode: 113 } );
this.$table.trigger(f2_event);
});
это, кажется, делает трюк.
режим редактирования по клику:
afterSelectionEnd: function (r, c, r2, c2) {
if (r == r2 && c == c2) {
getActiveEditor().beginEditing();
getActiveEditor().enableFullEditMode();
}
}
при добавлении enableFullEditMode(); каретка перемещается в ячейку при нажатии левой или правой кнопки вместо перехода в другую ячейку.
Anaother пример: только первая строка:
afterSelectionEnd: function (r, c, r2, c2) {
if (r == r2 && c == c2) {
if (r == 0 && r2 == 0) {
getActiveEditor().beginEditing();
getActiveEditor().enableFullEditMode();
}
}
}