Вот в чем дело.
У меня есть несколько значков, каждый из которых показывает сообщение в div.
при наведении курсора на иконку появляется окно, когда я щелкаю мышью, оно закрывается.
когда я нажимаю, я хочу, чтобы окно не закрывалось автоматически, а только после того, как я щелкну X в углу этого поля.
все это работало хорошо, пока я не добавил анимацию.
проблема в том, что селектор ":animated"
, кажется, не работает НИКОГДА, а ":visible"
, кажется, работает неисправно.
при наведении курсора на значок запускается анимация, когда я нажимаю на значок во время анимации, я хочу, чтобы он не закрывался при наведении курсора вместо этого, когда я щелкаю его сейчас, он немедленно запускает закрывающую анимацию.
код:
$(document).ready(function () {
$(".flyoutdialog").hide();
$('.flyouticon').click(function () {
//alert("click");
//when i click and this function gets called DURING animation i get:
alert($(this).next(".flyoutdialog").is(":visible")); //false
alert($(this).next(".flyoutdialog").is(":animated")); //false
$(this).next(".flyoutdialog").data("clicked", true);
showDialog($(this));
return false;
});
$('.flyouticon').hoverIntent({
over: function () {
showDialog($(this));
},
timeout: 500,
out: function () {
hideDialog($(this));
}
});
$(".closedialog").click(function () {
var dialog = $(this).parent().parent();
dialog.removeData("clicked");
hideDialog(dialog.prev(".flyouticon"));
});
});
function showDialog(button) {
var dialog = button.next(".flyoutdialog");
alert(dialog.is(":visible")); //false
alert(dialog.is(":animated")); //false
if (!dialog.is(":visible") && !dialog.is(":animated")) { //tried to not run this code when the dialog is not open nor is it in an animation.
//close all the other dialogs
$(".flyoutdialog").each(function () {
//$(".flyoutdialog:visible") DID return RESULTS (1), the one under animation
if ($(this).is(":visible")) {
alert($(this).is(":visible")); //true??????? why is this true now?
alert($(this).is(":animated")); //STILL false! and that during animation....
if ($(this)[0] === dialog[0]) { //this equal thing is false so the hidedialog gets called
//alert("hide");
} else {
dialog.removeData("clicked");
hideDialog($(this).prev(".flyouticon"));
}
}
});
var offset = button.offset();
dialog.offset({ top: offset.top - 5, left: offset.left + 25 });
dialog.show("blind", { direction: "horizontal" }, 1500);
}
}
function hideDialog(button) {
var dialog = button.next(".flyoutdialog");
//alert(dialog.data("clicked"));
if (!dialog.data("clicked")) {
dialog.hide("blind", { direction: "horizontal" }, 1500);
}
}
это я или это ошибка в jQuery, или я должен сделать это по-другому?
HTML:
<div class="editor-field">
<input id="postcode" name="postcode" value="" type="text">
<a href="#" class="flyouticon">
<img src="/img/help.png" alt="Flyout" width="16"></a>
<div style="display: none; top: 370px; left: 315.55px;" class="flyoutdialog grayicon" title="Postcode">
<div class="title">
<h4>
Postcode</h4>
<span class="closedialog ui-icon ui-icon-closethick"> </span>
</div>
<p>
De postcode kan je met een asterix (*) invullen om zo een reeks van postcodes op te zoeken.<br> Bijvoorbeeld: 92** geeft alle postcodes terug tussen 9200 en 9299</p>
</div>
</div>
<div class="editor-label">
<label for="Gebruikerscode">Gebruikerscode</label>
</div>
<div class="editor-field">
<input id="gebruikerscode" name="gebruikerscode" value="" type="text">
<a href="#" class="flyouticon">
<img src="/img/help.png" alt="Flyout" width="16"></a>
<div style="display: none;" class="flyoutdialog grayicon" title="Gebruikerscode">
<div class="title">
<h4>
Gebruikerscode</h4>
<span class="closedialog ui-icon ui-icon-closethick"> </span>
</div>
<p>
Dit is de code of 'gebruikersnaam' waarmee de school inlogt. Deze is uniek.</p>
</div>
</div>
Редактировать 2:
если я запускаю этот код в функции showDialog
alert(dialog.html());
когда я нажимаю на кнопку, чтобы вызвать это событие, когда это диалоговое окно анимируется, оно предупреждает null
так вот где моя проблема. но как мне это исправить, и почему это так.