Javascript 如何在jquery对话框窗体中添加日期选择器
我正在尝试使用jquery表单,在开始时间和结束时间字段中需要一个日期选择器。我已经为上述字段使用了一个id,因此无法使用id=“datepicker”。有人能告诉我还有什么别的方法吗Javascript 如何在jquery对话框窗体中添加日期选择器,javascript,jquery,date,datepicker,Javascript,Jquery,Date,Datepicker,我正在尝试使用jquery表单,在开始时间和结束时间字段中需要一个日期选择器。我已经为上述字段使用了一个id,因此无法使用id=“datepicker”。有人能告诉我还有什么别的方法吗 <!doctype html> <html lang="en"> <head> <meta charset="utf-8" /> <title>jQuery UI Dialog - Modal form</
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jQuery UI Dialog - Modal form</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css" />
<style>
body {
font-size: 62.5%;
}
label, input {
display:block;
}
input.text {
margin-bottom:12px;
width:95%;
padding: .4em;
}
fieldset {
padding:0;
border:0;
margin-top:25px;
}
h1 {
font-size: 1.2em;
margin: .6em 0;
}
div#users-contain {
width: 350px;
margin: 20px 0;
}
div#users-contain table {
margin: 1em 0;
border-collapse: collapse;
width: 100%;
}
div#users-contain table td, div#users-contain table th {
border: 1px solid #eee;
padding: .6em 10px;
text-align: left;
}
.ui-dialog .ui-state-error {
padding: .3em;
}
.validateTips {
border: 1px solid transparent;
padding: 0.3em;
}
</style>
<script>
$(function() {
var name = $("#name"),
StartTime = $("#StartTime"),
EndTime = $("#EndTime"),
allFields = $([]).add(name).add(StartTime).add(EndTime),
tips = $(".validateTips");
function updateTips(t) {
tips.text(t)
.addClass("ui-state-highlight");
setTimeout(function() {
tips.removeClass("ui-state-highlight", 1500);
}, 500);
}
function checkLength(o, n, min, max) {
if (o.val().length > max || o.val().length < min) {
o.addClass("ui-state-error");
updateTips("Length of " + n + " must be between " + min + " and " + max + ".");
return false;
} else {
return true;
}
}
function checkRegexp(o, regexp, n) {
if (!(regexp.test(o.val()))) {
o.addClass("ui-state-error");
updateTips(n);
return false;
} else {
return true;
}
}
$("#dialog-form").dialog({
autoOpen: false,
height: 300,
width: 350,
modal: true,
buttons: {
"Create an account": function() {
var bValid = true;
allFields.removeClass("ui-state-error");
if (true) {
$("#users tbody").append("<tr>" +
"<td>" + name.val() + "</td>" +
"<td>" + StartTime.val() + "</td>" +
"<td>" + EndTime.val() + "</td>" +
"</tr>");
$(this).dialog("close");
}
},
Cancel: function() {
$(this).dialog("close");
}
},
close: function() {
allFields.val("").removeClass("ui-state-error");
}
});
$("#create-user")
.button()
.click(function() {
$("#dialog-form").dialog("open");
});
});
</script>
</head>
<body>
<div id="dialog-form" title="Create new user">
<p class="validateTips">All form fields are required.</p>
<form>
<fieldset>
<label for="name">Name</label>
<input type="text" name="name" id="name" class="text ui-widget-content ui-corner-all" />
<label for="StartTime">Start Time</label>
<input type="text" name="StartTime" id="StartTime" value="" class="text ui-widget-content ui-corner-all" id="datepicker" />
<label for="EndTime">End Time</label>
<input type="password" name="EndTime" id="EndTime" value="" class="text ui-widget-content ui-corner-all" />
</fieldset>
</form>
</div>
<div id="users-contain" class="ui-widget">
<h1>Appointment Details</h1>
<table id="users" class="ui-widget ui-widget-content">
<thead>
<tr class="ui-widget-header ">
<th>Name</th>
<th>Start Time</th>
<th>End Time</th>
</tr>
</thead>
<tbody>
<tr>
<td>John Doe</td>
<td>john.doe@example.com</td>
<td>johndoe1</td>
</tr>
</tbody>
</table>
</div>
<button id="create-user">Create Appointments</button>
</body>
</html>
jQueryUI对话框-模态表单
身体{
字体大小:62.5%;
}
标签,输入{
显示:块;
}
input.text{
边缘底部:12px;
宽度:95%;
填充:.4em;
}
字段集{
填充:0;
边界:0;
边缘顶部:25px;
}
h1{
字体大小:1.2米;
边缘:.6em0;
}
div#用户包含{
宽度:350px;
利润率:20px0;
}
div#用户包含表{
利润率:1米0;
边界塌陷:塌陷;
宽度:100%;
}
div#用户包含表td,div#用户包含表th{
边框:1px实心#eee;
填充:.6em10px;
文本对齐:左对齐;
}
.ui对话框.ui状态错误{
填充:.3em;
}
.validateips{
边框:1px实心透明;
填充:0.3em;
}
$(函数(){
变量名称=$(“#名称”),
开始时间=$(“#开始时间”),
EndTime=$(“#EndTime”),
allFields=$([]).add(名称).add(开始时间).add(结束时间),
提示=$(“.validateips”);
函数更新(t){
提示.文本(t)
.addClass(“ui状态突出显示”);
setTimeout(函数(){
removeClass(“ui状态突出显示”,1500);
}, 500);
}
函数校验长度(o、n、最小值、最大值){
如果(o.val().length>max | | o.val().length所有表单字段都是必需的
名称
开始时间
结束时间
预约详情
名称
开始时间
结束时间
无名氏
厕所。doe@example.com
约翰多尔
创建约会
我发现您的代码存在一些问题,但严格来说,这里的问题是您必须解决的
...
<input type="text" name="StartTime" id="StartTime" value="" class="text ui-widget-content ui-corner-all" id="datepicker"/>
<label for="EndTime">End Time</label>
<input type="password" name="EndTime" id="EndTime" value="" class="text ui-widget-content ui-corner-all" />
...
。。。
结束时间
...
- 注意,您的第一个输入有两个ID,您应该去掉第二个ID
- 我看到您正在使用jQueryUI作为datepicker插件,因此您应该知道datepicker需要像这样显式调用
- 我看到你的第二个输入是密码类型。我认为应该是文本