У меня возникают проблемы с розжига же событие на всех DIVs, которые имеют класс «карты», как показано на скриншоте ниже:Как установить кнопку события на все DIV с тем же классом
<div class="row">
<div class="col-md-1">
<div class="margin"></div>
<div class="card">
<div class="front">CardClick</div>
<div class="back">1</div>
</div>
</div>
<div class="col-md-1">
<div class="margin"></div>
<div class="card">
<div class="front">CardClick</div>
<div class="back">2</div>
</div>
</div>
<div class="col-md-1">
<div class="margin"></div>
<div class="card">
<div class="front">CardClick</div>
<div class="back">4</div>
</div>
</div>
<div class="col-md-1">
<div class="margin"></div>
<div class="card">
<div class="front">CardClick</div>
<div class="back">5</div>
</div>
</div>
</div>
<div class="row">
<div class="col-md-1">
<div class="margin"></div>
<div class="card">
<div class="front">CardClick</div>
<div class="back">4</div>
</div>
</div>
<div class="col-md-1">
<div class="margin"></div>
<div class="card">
<div class="front">CardClick</div>
<div class="back">5</div>
</div>
</div>
<div class="col-md-1">
<div class="margin"></div>
<div class="card">
<div class="front">CardClick</div>
<div class="back">6</div>
</div>
</div>
<div class="col-md-1">
<div class="margin"></div>
<div class="card">
<div class="front">CardClick</div>
<div class="back">4</div>
</div>
</div>
</div>
Я установил свой обработчик, как :
$(".card").click(function() {
alert("clicked...");
});
Проблема заключается в том, что окно предупреждения появляется только для тех DIV, помеченных как черный на скриншоте ниже. Для всех остальных полей строка alert("clicked...")
не выполняет событие.
Даже поле, помеченное как 5 в верхней строке, имеет поле предупреждения, только если оно щелкнуто в правом верхнем углу. При нажатии на любое другое место в этом поле не запускается предупреждение. (Коробки в нижней строке не имеют этой проблемы, оповещение для них кажется прекрасным, если щелкнуть внутри них где угодно).
Это как-то связано с Event Bubbling или Event Catching? Как я могу исправить это так, чтобы предупреждение вызывалось для всех DIV с классом «карта»?
Update: Связанные CSS выглядеть следующим образом:
.card {
width: 100px;
height: 100px;
position: absolute;
-webkit-transition: -webkit-transform 1s;
-moz-transition: -moz-transform 1s;
-o-transition: -o-transform 1s;
transition: transform 1s;
-webkit-transform-style: preserve-3d;
-moz-transform-style: preserve-3d;
-o-transform-style: preserve-3d;
transform-style: preserve-3d;
-webkit-transform-origin: 50% 50%;
}
.card div {
display: block;
height: 100%;
width: 100%;
line-height: 100px;
color: black;
text-align: center;
font-weight: bold;
font-size: 16px;
position: absolute;
-webkit-backface-visibility: hidden;
-moz-backface-visibility: hidden;
-o-backface-visibility: hidden;
backface-visibility: hidden;
}
.card .front {
background: white;
border-color: black;
border-width: 3px;
border-style: solid;
color:black;
}
.card .back {
background: black;
color:white;
-webkit-transform: rotateY(180deg);
-moz-transform: rotateY(180deg);
-o-transform: rotateY(180deg);
transform: rotateY(180deg);
}
.margin {
margin-top: 200%;
}
Update - Добавлен HTML код на вопрос. Раньше у меня был снимок экрана. «col-md-1» и т. д. - то, как twitter bootstrap помогает выложить сетку.
Вы можете сделать jsfiddle с кодом HTML и CSS? – Andy
Эта проблема может быть не проблемой js, а проблемой css/html. – rottenoats
Да, нет никаких подсказок о том, как вы чертили черно-белые карты по-разному. Я подозреваю, что CardClick - это «фиктивный» div, а черная карта - «карта». Так будет проблема HTML/CSS, где «карта» равна 0 ширине и высоте (без кликаемой цели). – Akurn