引导日期选择器位置

时间:2018-07-10 12:45:35

标签: javascript twitter-bootstrap-3 datepicker

我将以下示例代码用于日期选择器

<html>
<head>
<!--  jQuery -->
<script type="text/javascript" src="https://code.jquery.com/jquery-1.11.3.min.js"></script>
<!-- Isolated Version of Bootstrap, not needed if your site already uses Bootstrap -->
<link rel="stylesheet" href="https://formden.com/static/cdn/bootstrap-iso.css" />

<!-- Bootstrap Date-Picker Plugin -->
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-datepicker/1.4.1/js/bootstrap-datepicker.min.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-datepicker/1.4.1/css/bootstrap-datepicker3.css"/>


</head>
<body>
<div class="bootstrap-iso">
    <div class="container-fluid">
    <div class="row">
    <div class="col-md-6 col-sm-6 col-xs-12">

    <!-- Form code begins -->
    <form method="post">
        <div class="form-group"> <!-- Date input 1-->
            <label class="control-label" for="date">Start Date</label>
            <input class="form-control" id="date" name="date" placeholder="MM/DD/YYY" type="text"/>
        </div>
        <div class="form-group"> <!-- Date input 2-->
            <label class="control-label" for="date">End Date</label>
            <input class="form-control" id="date1" name="date1" placeholder="MM/DD/YYY" type="text"/>
        </div>
        <div class="form-group"> <!-- Submit button -->
            <button class="btn btn-primary " name="submit" type="submit">Submit</button>
        </div>
    </form>
 <!-- Form code ends --> 
    </div>
    </div>    
    </div>
    <script>
        $(document).ready(function(){
            var date_input=$('input[name="date"]'); //our date input has the name "date"
            var date_input1=$('input[name="date1"]'); //our date input has the name "date"
            var container=$('.bootstrap-iso form').length>0 ? $('.bootstrap-iso form').parent() : "body";
            var options={
                format: 'mm/dd/yyyy',
                container: container,
                todayHighlight: true,
                autoclose: true,
            };
            date_input.datepicker(options);
            date_input1.datepicker(options);
        })
    </script>
</div>
</body> 
</html>

Start Date的日期选择器在正确的位置打开,而End Date的日期选择器在字段上方打开。我想在下面打开它,类似于第一种情况。我猜问题出在javascript,而javascript对我来说是新事物。我该如何纠正错误?

2 个答案:

答案 0 :(得分:1)

在编程中使用任何新内容时,最好查阅相关工具的文档以发现可以做什么和不能做什么。在这种情况下,我用Google搜索了bootstrap-datepicker,并在这里找到了文档:Options Doc

阅读文档后,您会发现有一个可以设置的方向属性。将您的options变量修改为以下值可以解决您的问题:

var options={
            format: 'mm/dd/yyyy',
            container: container,
            todayHighlight: true,
            autoclose: true,
            orientation: 'bottom'
        };

让我知道怎么回事!

答案 1 :(得分:1)

如果将方向:“顶部”添加到选项中,则应该可以使用。

https://jsfiddle.net/L4t68rzx/1/

var options={
    format: 'mm/dd/yyyy',
    container: container,
    todayHighlight: true,
    autoclose: true,
    orientation: 'top' 
};