我正在尝试创建一个带有花哨框的表单,即使它显示输入元素和正确的标记,但是单击表单中的任何内容都会导致fancybox刷新。我错过了什么来禁用点击事件气泡,以便您可以实际进入文本输入框或选择形式选择选项而不刷新花式框?
$(document).ready(function() {
var box = $("#show_mailing_list_signup");
box.fancybox({
'showCloseButton': true,
'scrolling': 'no',
'titleShow': false,
'beforeLoad': function() {
return !hideMailList();
},
'afterLoad': function() {
$('#disableSignup').click(function() {
setCookie("hideSignup", true, 365);
$.fancybox.close();
return false;
});
$("#send_form").click(function() {
return false;
});
}
}).click();
});
<div id="show_mailing_list_signup">
<form id="mailinglistForm" method="post">
<h2>Header</h2>
<label for="name">* Name </label>
<p>
<input name="fname" type="text" id="name" minlength="4" maxlength="15" />
</p>
<br />
<label for="email">* Email </label>
<p>
<input name="email" type="text" id="email" />
</p>
<br />
<label for="state">Pick your favorite school</label>
<p>
<select id="state">
<option>NY</option>
<option>IL</option>
</select>
<select id="city">
<option>Schenectedy</option>
<option>Fishkill</option>
</select>
</p>
<p>
<input id="schoolSearch" type="text"/>
</p>
<%--default to the most select school--%>
<p style="margin-top: 20px;">
<input value="Join Now" type="button" name="send_form" id="send_form" />
</p>
</form>
<p class="details">blah</p>
<a href="#" id="disableSignup">don't show again</a>
</div>
答案 0 :(得分:5)
当你这样做时
var box = $("#show_mailing_list_signup");
box.fancybox().click()
元素<div id="show_mailing_list_signup">
(包含您在fancybox中打开的表单)成为 触发器 和 目标 的fancybox所以你在容器内click
的任何东西都会一遍又一遍地触发fancybox。
将选择器更改为其他内容以定位您的表单,如
var box = $(".fancybox");
box.fancybox({
// API options here
}).click();
注意:您仍需要使用class="fancybox"
的html元素(通常是链接)定位form
,如:
<a class="fancybox" href="#show_mailing_list_signup"></a>