|
|
|
| Маленькая загвоздка с onlick и обычной ссылкой.
Пример:
<table onclick="code">
<tr>
<td>
<td><a href="#" onclick="code">link</a>
</table>
|
Когда нажимаю на ссылку onclick срабатывает и тот, который на саму таблицу распространяется.
Как быть? | |
|
|
|
|
|
|
|
для: Maxam
(08.08.2010 в 22:48)
| | возможно так:
<table onclick="var e = event || window.event; e = e.target || e.srcElement; if(!e.tagName || e.tagName != 'A'){ code }">
<tr>
<td>
<td><a href="#" onclick="code">link</a>
</table>
|
| |
|
|
|
|
|
|
|
для: sl1p
(08.08.2010 в 22:51)
| | В code (которая к таблице применяется) у меня подключается функция, а ссылка <a href="#" onclick="code">link</a> иногда бывает <span onclick="code">link</span>. Отсюда 2 вопроса:
1. Можно ли ваши условия в саму функцию вставить?
2. Будет ли работать, если тег не A а SPAN? | |
|
|
|
|
|
|
|
для: Maxam
(10.08.2010 в 15:16)
| | Уберите все вызовы функции из дочерних элементов таблицы, и обрабатывайте onclick собитые таблицы, и определяя в функции источник события, действуйте как вам необходимо. | |
|
|
|
|
|
|
|
для: sim5
(10.08.2010 в 16:15)
| | Не совсем понял. | |
|
|
|
|
|
|
|
для: Maxam
(11.08.2010 в 14:08)
| |
<script>
function getSource(e) {
return (e.target) ? e.target : e.srcElement;
}
function func(e) {
alert(e.tagName);
}
</script>
<table onclick="func(getSource(event))" border="1">
<tr><td><a href="#">LINK</a></td></tr>
<tr><td><span>SPAN</span></td></tr>
<tr><td><div>DIV</div></td></tr>
<tr><td><p>P</p></td></tr>
<tr><td> </td></tr>
</table>
|
| |
|
|
|
|
|
|
|
для: sim5
(11.08.2010 в 14:28)
| | Спасибо. | |
|
|
|
|
|
|
|
для: Maxam
(11.08.2010 в 14:08)
| | Ещё один выход - использовать JQuery:
$('#link').bind('click', function() {
...actions...
return false;
});
$('#table').bind('click', function() {
...actions...
return false;
});
|
| |
|
|
|
|
|
|
|
для: bishake
(13.08.2010 в 12:26)
| | Зачем? | |
|
|
|
|
|
|
|
для: sim5
(13.08.2010 в 14:35)
| | просто ради парочки мелких функций таскать с собой целую библиотеку это сейчас круто и модно ;) | |
|
|
|
|
|
|
|
для: psychomc
(13.08.2010 в 16:50)
| | Дело не в библиотеке, ничего в этом плохого нет, если она уже используется. А вот к чему обрабатывать одно и тоже событие у дочерних элементов, которое обрабатывается и у родителя, и при этом обращение происходит к одной и той же функции? | |
|
|
|
|
|
|
|
для: bishake
(13.08.2010 в 12:26)
| | jQuery можно - она уже используется у меня. Спасибо. Попробую. | |
|
|
|