自定义下拉列表向上滑动,如果我与jQuery日期选择器交互

custom dropdown slide up if I interact into jquery datepicker

本文关键字:jQuery 日期 交互 选择器 如果 下拉列表 自定义      更新时间:2023-09-26

这里的问题是,当我与jquery u界面日期选择器交互时,具有filter_sub类(自定义菜单下拉菜单(的div正在向上滑动(单击此元素及其后代以外的任何地方时隐藏内容(。

有什么想法、线索、帮助、建议、建议来解决我的问题吗?

我希望自定义菜单下拉菜单(具有一类filter_sub的下拉菜单(在我交互进入jquery ui date picker时不会向上滑动,或者锐化其他jquery ui datepicker和自定义下拉菜单,当单击任意位置时,jquery ui 日期选择器将被隐藏,自定义下拉菜单将向上滑动(隐藏(。

$(document).ready(function(){
  $(".thehide").hide();
  $( ".datepicker" ).datepicker({
            dateFormat: "yy-mm-dd"
        });
       //when authorized person clicks on the attendance menu
        $(".filter_pages").unbind().click(function(e){
              $(this).next(".filter_sub").slideToggle();
              e.preventDefault();
          });
        $(document).mouseup(function(e)
          {
              var container = $(".filter_sub");
              var calendar = $(".ui-datepicker");
              if (!container.is(e.target) // if the target of the click isn't the container...
&& container.has(e.target).length === 0)  // ... nor a descendant of the container
              {
                      container.slideUp();
              }
          });
  
});
.filter .filter_has_sub{
    padding: 0px;
    margin: 0px;
    float: left;
    margin-left: 7px;
}
.filter_pages{
    display: table;
    font: normal 12px 'mpregular', san-serif;
    padding: 7px;
    color: #7e7e7e;
    margin-top: 4px;
}
.filter_pages span, .filter_sub a span{
    float: left;
    display: block;
}
.filter_pages span:first-child, .filter_sub a span:first-child{
    margin-right: 6px;
}
.filter_pages span:last-child{
    font-size: 8px;
    padding-top: 3px;
}
.filter_has_sub:first-child .filter_sub{
    margin-left: -100px;
    width: 170px;
}
.filter_has_sub:first-child .filter_sub .filter_datepicker{
    border: 1px solid #ccc;
    display: table;
    margin: 5px auto;
}
.filter_has_sub:first-child .filter_sub .filter_datepicker span{
    display: block;
    margin: 0px 5px 0px 0px;
    float: left;
    font-size: 20px;
    padding: 5px 0px 0px 5px;
    color: #7e7e7e;
}
.filter_has_sub:first-child .filter_sub .datepicker{
    padding: 5px;
    border: none;
    margin: 0px;
    display: block;
    float: left;
    width: 120px;
}
.filter_sub{
    background: #fff;
    position: absolute;
    z-index: 99999999;
    width: 100px;
    margin-left: -30px;
    padding: 10px 5px;
    margin-top: 5px;
    
    -webkit-box-shadow: 0 1px 5px rgba(0, 0, 0, 0.15);
    -moz-box-shadow: 0 1px 5px rgba(0, 0, 0, 0.15);
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.15);
}
.filter_sub a{
    clear: both;
    float: none;
    display: block;
    padding: 5px 10px;
    font: normal 14px 'mplight', sans-serif;
    color: #555;
    text-transform: uppercase;
}
.filter_sub a:hover{
    color: #555;
}
.thehide{dsiplay: none;}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<link href="https://code.jquery.com/ui/1.11.3/themes/smoothness/jquery-ui.css" rel="stylesheet"/>
<script src="https://code.jquery.com/ui/1.11.3/jquery-ui.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet"/>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
<div class="filter_has_sub extend data_filter" style="display: table; margin: 0px auto;">
                <a href="#" class="btn btn-default filter_pages"><span>Filter Data</span><span class="ion-chevron-down"></span></a>
                    <div class="filter_sub thehide" id="pagesfilter">
                            <div class="extend clear" style="height: 5px;"></div>
                            <div class="filter_datepicker extend clear">
                                <span class="ion-calendar"></span><input class="form-control datepicker extend" name="from_what_date" placeholder="From what date" required/>
                            </div>
                            <div class="filter_datepicker extend clear">
                                <span class="ion-calendar"></span><input class="form-control datepicker extend" name="to_what_date" placeholder="To what date" required/>
                            </div>
                            <button class="btn btn-default center display_table" id="date_filter_button">Go</button>
                    </div>
              </div>

我想你快到了。以下是您可以执行的操作:

  • 在函数内的if子句mouseup添加另一个条件: calendar.has(e.target).length===0 .哪个做与其他类似条件相同,即确保现任target不是ui-datepicker的后代元素。
  • 另外,我注意到,如果您单击click元素以隐藏内部元素,则事件slideTogglemouseup事件中的slideUp会依次执行filter_has_sub。简单的解决方法是在滑动slideToggleslideUp调用之前添加一个stop(true)

.JS:

$(document).ready(function () {
    $(".thehide").hide();
    $(".datepicker").datepicker({dateFormat: "yy-mm-dd"});
    $(".filter_pages").unbind().click(function (e) {
        $(this).next(".filter_sub").stop(true).slideToggle();
        e.preventDefault();
    });
    $(document).mouseup(function (e) {
        var container = $(".filter_sub");
        var calendar = $(".ui-datepicker");
        if (!container.is(e.target) && calendar.has(e.target).length === 0 && container.has(e.target).length === 0) {
            container.stop(true).slideUp();
        }
    });
});

希望这有帮助。

菜单已经启用了toggle,所以没问题。因此,如果您所要做的就是检查nodeName是否是 HTML,如果用户在目标之外单击,请将其UI calender或幻灯片的input box

因此,您不必检查container.is(e.target)

这就是你可以做到的方法==> (event.target.nodeName === 'HTML')

查看更新的小提琴

有关更多信息,请查看 jQuery Docs- event.target