Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/435.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/jquery/73.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何在jquery对话框窗体中添加日期选择器_Javascript_Jquery_Date_Datepicker - Fatal编程技术网

Javascript 如何在jquery对话框窗体中添加日期选择器

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</

我正在尝试使用jquery表单,在开始时间和结束时间字段中需要一个日期选择器。我已经为上述字段使用了一个id,因此无法使用id=“datepicker”。有人能告诉我还有什么别的方法吗

<!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需要像这样显式调用
$(“#开始时间,#结束时间”).datepicker(); 您不必为它们定义特定的ID。查看示例/文档以了解更多信息

  • 我看到你的第二个输入是密码类型。我认为应该是文本

有很多不同的方法可以做到这一点,但为什么不直接使用已有的开始时间和结束时间ID呢?e、 g.$(“#开始时间”).datepicker();仅仅因为他们的例子说“日期采集器”,并不意味着你的必须是相同的。您可能需要阅读API文档,我只是在测试它,还没有完全完成。我试过这样,你说的是$(“#开始时间,#结束时间”).da $("#StartTime, #EndTime").datepicker();