阻止 jQuery UI 对话框将焦点设置为第一个文本框
2022-08-30 02:31:01
我已经设置了一个jQuery UI模式对话框,当用户单击链接时显示。该对话框 div 标记中有两个文本框(为了简洁起见,我只显示 1 的代码),它被更改为对焦点做出反应的 jQuery UI DatePicker 文本框。
问题在于,jQuery UI 对话框(“打开”)以某种方式触发了第一个文本框以获得焦点,然后触发日期选取器日历立即打开。
因此,我正在寻找一种方法来防止焦点自动发生。
<div><a id="lnkAddReservation" href="#">Add reservation</a></div>
<div id="divNewReservation" style="display:none" title="Add reservation">
<table>
<tr>
<th><asp:Label AssociatedControlID="txtStartDate" runat="server" Text="Start date" /></th>
<td>
<asp:TextBox ID="txtStartDate" runat="server" CssClass="datepicker" />
</td>
</tr>
</table>
<div>
<asp:Button ID="btnAddReservation" runat="server" OnClick="btnAddReservation_Click" Text="Add reservation" />
</div>
</div>
<script type="text/javascript">
$(document).ready(function() {
var dlg = $('#divNewReservation');
$('.datepicker').datepicker({ duration: '' });
dlg.dialog({ autoOpen:false, modal: true, width:400 });
$('#lnkAddReservation').click(function() { dlg.dialog('open'); return false; });
dlg.parent().appendTo(jQuery("form:first"));
});
</script>