当鼠标离开触发器并滑下内容时,如何将滑动的内容编码为滑动?

时间:2017-06-29 15:01:13

标签: jquery html css drop-down-menu slide

当鼠标离开此div时,我已经让webdsn-drop向上滑动但当鼠标离开#web按钮时它仍然保持向上。当鼠标关闭#web按钮和#webdsn-drop

时,如何使div消失

感谢您的帮助!

HTML:

<div id="navbar">
    <div id="nav-container">
        <h1>PORTFOLIO</h1>
        <a href="#">Logo Design</a>
        <a href="#">Business Cards</a>
        <a id="pf" href="posters+flyers.html">Posters & Flyers</a>
        <a id="web" href="#">Website Design</a>
    </div>
  </div>

    <div id="webdsn-drop">
        <div id="border">
        <h1>WEBSITE DESIGN</h1>
        </div>

    </div>

    <div id="pfdsn-drop">
        <div id="border">
        <h1>POSTERS & FLYERS</h1>
        </div>

    </div>

CSS:

#navbar {
    width: 100%;
    background-color: #fcfcfc;
    overflow: auto;
    position: fixed;
    left: 0px;
    top: 0px;
    overflow: hidden;
    z-index: 10;

}

#nav-container {
    max-width: 950px;
    min-width: 745px;
    margin: 0 auto;


}

#nav-container h1 {
    float: left;
    margin: 0 auto;
    padding-top: 10px;
    font-family: "calibri light";
    font-size: 25px;
    letter-spacing: 0.3em;
    margin-left: 5px;
    transition: color 0.3s ease;

}

#nav-container a {
    float: right;
    display: block;
    padding: 15px 15px;
    text-decoration: none;
    color: black;
    font-family: "calibri light", sans-serif;
    font-size: 18px;
    transition: background-color 0.5s ease;

}

#nav-container a:hover {
    background-color: #f4f4f4;
    transition: background-color 0.5s ease;
}

#nav-container a:active {
    background-color: #bfbfbf;
}

#nav-container h1:hover {
    color: #aaaaaa;
    transition: color 0.3s ease;
}

/*-----------WEB-DESIGN-DROP---------*/

#border{
    width: 950px;
    margin: 0 auto;
}

#border h1{
    position: absolute;
    border: solid;
    border-color: white;
    border-width: 1px;
    display: inline;
    padding: 10px 20px;
    border-radius: 10px;
}


#webdsn-drop{
    background-color: #3f3f3f;
    margin-top: 50px;
    width: 100%;
    position: fixed;
    left: 0px;
    top: 0px;
    z-index: 9;
    font-family: 'calibri light';
    font-size: 12px;
    letter-spacing: 5px;
    height: 400px;
    color: white;
    display: none;
}

JQUERY:

$(document).ready(function(){
    $('#web').hover(function() {
  $('#webdsn-drop').slideDown();
}, function() {
    $('#webdsn-drop').mouseleave(function(){
  $('#webdsn-drop').slideUp();
    });
});



});

3 个答案:

答案 0 :(得分:1)

我坐了很长时间,想着如何实现它,虽然结果如此歪曲,但我完全相信有更好的实现

  $(document).ready(function () {

            let StatusHower = false;

            $('#web').hover(function () {
                if ($('#webdsn-drop').is(":hidden")) {
                    $('#webdsn-drop').slideDown();
                }
            }, function () {

                StatusHower = true;

                $('#webdsn-drop').hover(function () {
                    StatusHower = false;
                }, function () {
                    $('#webdsn-drop').slideUp();
                    });


                setTimeout(function () {
                    if (StatusHower) {
                        $('#webdsn-drop').slideUp();
                        StatusHower = !StatusHower;
                    }
                },100)

                });
        });

答案 1 :(得分:0)

在我看来,你正试图在事件被触发时添加一个mouseleave监听器。

试试这个:

$(document).ready(function(){
  $('#web').hover(function() {
    $('#webdsn-drop').slideDown();
  }, function() {
    $('#webdsn-drop').slideUp();
  });
});

答案 2 :(得分:0)

试试吧

我添加了 $('#web')行。悬停()为了不会重复打开多个悬停

 $(document).ready(function () {
            $('#web').hover(function () {
                if ($('#webdsn-drop').is(":hidden")) {
                    $('#webdsn-drop').slideDown();
                }
            }, function () {

                    $('#webdsn-drop').slideUp();
            });