Javascript-форум (https://javascript.ru/forum/)
-   Events/DOM/Window (https://javascript.ru/forum/events/)
-   -   Как узнать куда кликнули при blur (https://javascript.ru/forum/events/30757-kak-uznat-kuda-kliknuli-pri-blur.html)

Dim@ 14.08.2012 18:28

Цитата:

Сообщение от kolyan1983
В контексте моей задачи не тот ни другой вариант не работает/не подходит.

Подходит - говорят хрень - простите конечно беру слова обратно
Цитата:

Сообщение от kolyan1983
Оба варианта не подходят потому что придётся переписывать кучу стороннего кода jquery плагинов.

:blink: :blink:
здесь при чем тут плагины - вы хотите получить свойства элемента - их можно получить в новой функции где передается target пример выше это наглядно показал ;)
P.S. вы же читали код примера?

kolyan1983 14.08.2012 18:28

"и так можно получить все свойства " - и как же получить элемент по которому кликнули?

kolyan1983 14.08.2012 18:40

Цитата:

здесь при чем тут плагины - вы хотите получить свойства элемента
Может конечно я чего то жёстко не понимаю, но попробую объяснить. Мне нужно доработать jquery плагин. В нём вешается onblur примерно так: $('#element').blur(function(element){... И нужно внутри него определить куда кликнули. Вот эта штука alert(event.explicitOriginalTarget || event.toElement) добавленная в обработчик возвращает undefined в фф и null в ie8. А вариант с ф-ей blu вообще не представляется возможным.

Dim@ 14.08.2012 18:43

kolyan1983,
не тупите пожалуйста!
он же передается в вашу функцию и его можно алертить, вставлять и т.п.!
<script type="text/javascript">
function your_function(target){//ваша функция принимающая элемент
  alert("Элемент по которому кликнули после блура" + target + "ID элемента" + target.getAttribute("id"));
}
document.i = 0;
function blu(e){
 if (document.i != 5){return;}
 var e = e || window.event;
 var target = e.target || e.srcElement;
 your_function(target);//вызывайте свою функцию с тем элементом (который вам нужен)
//и там получайте его свойства
}
document.onclick = blu;
</script>
<div id="Это ид дива по которому ты щелкнул">Щелкни по мне что бы вызвалась твоя функция которая алертит мой ид</div>
<input type="text" onblur="document.i = 5;" onfocus="document.i = 0;">

P.S. также можно сделать так что бы клик срабатывал только один раз после блур-а - тогда надо добавить
document.i = 0;

после
var target = e.target || e.srcElement;

P.P.S. не видел пост выше - щас отвечу

Dim@ 14.08.2012 18:51

kolyan1983,
что же вам надо посочувствовать ибо нормально найти и кроссбраузерно у вас не получиться ;) и потом нахрена нужен тот плагин который вы пишите (что он будет делать и практическая ценность)?

kolyan1983 14.08.2012 18:56

ок. Я не пишу плагин. Задача требует приделать маскирование ввода в поле, к которому уже приделаны jquery validate + Query UI Datepicker. Получается конфликт. Вот и хотел немного подпилить плагин http://digitalbush.com/projects/masked-input-plugin/

Dim@ 14.08.2012 18:58

kolyan1983,
ясно - тогда вам нужен не я - я не знаю JQ :)

Aetae 14.08.2012 18:59

Вообще есть ещё такая штука как document.activeElement, но это не совсем то.

Dim@ 14.08.2012 19:02

Aetae,
активный элемент :blink: :blink:

Aetae 14.08.2012 19:09

<input onblur="setTimeout(function(){document.body.appendChild(document.createElement('div')).innerHTML=document.activeElement},10)">
<textarea onblur="setTimeout(function(){document.body.appendChild(document.createElement('div')).innerHTML=document.activeElement},10)"></textarea>

Работает только с редактируемыми элементами и body.
Таймаут нужен, т.к. в момент блюра ещё ни один элемент не успел получить фокуса.


Часовой пояс GMT +3, время: 21:50.