|
|
|
| См. аттач.
Это упрощенный вариант приложения, суть которого позволить вносить изменения в таблицу пользователем. Первоначально задумывалось, что пользователь нажимает на нужный текст (тут строка0, строка1) и спустя секунду вместо текста появляется поле ввода, содержащее выделенный исходный текст. Познее решил упростить до обычного нажатия, но вот беда - по неясной причине функция select() перестала отрабатывать.
В данном примере функция startEditLabel() отвечает за задержку
function startEditLabel()
{
if(editCounter>=0 && editCounter<10){
editCounter = editCounter + 1;
setTimeout('startEditLabel()',timeoutEdit);
return;
}
if(editCounter==10){
var el = editEl.previousSibling;
el.value = editEl.innerHTML;
editEl.style.display='none';
el.style.display='inline';
el.select();
return;
}
}
Если ее изменить так
function startEditLabel()
{
var el = editEl.previousSibling;
el.value = editEl.innerHTML;
editEl.style.display='none';
el.style.display='inline';
el.select();
return;
}
то задержки не будет, но и выделения текста в поле ввода не произойдет. Приходится его выделять вручную. Где я не прав и как исправить ? | |
|
|
|
|
|
|
|
для: Duran
(07.08.2007 в 17:04)
| | В любом варианте (с задержкой или без) попробуйте сначала дать элементу el фокус, а уж потом выделять select'ом. И в любом случае запустите это для гарантии отработки через setTimeout.
Для чего вместо el.select (); пропишите GLOB = el; setTimeout ('with (GLOB) {focus (); select ()}', 0); (переменную GLOB сделайте глобальной - определите её вне функции var GLOB;) | |
|
|
|