单击内部按钮时如何隐藏下拉菜单

时间:2019-11-29 14:35:31

标签: javascript css reactjs

我有一个下拉列表,如下所示:

<div className="dropdown">
    <button className="nav-btn pick-a-sort">PICK A SORT:</button>
    <div className = "dropdown-content">
        <button className="nav-btn" id = "bubble-sort" onClick = {()=>{this.bubbleSort()}}>BUBBLE SORT</button>
        <button className="nav-btn" id = "selection-sort" onClick = {()=>{this.selectionSort()}}>SELECTION SORT</button>
        <button className="nav-btn" id = "insertion-sort" onClick = {()=>{this.insertionSort()}}>INSERTION SORT</button>
        <button className="nav-btn" id = "quick-sort" onClick = {()=>{this.quickSort()}}>QUICK SORT</button>
        <button className="nav-btn" id = "merge-sort" onClick = {()=>{this.mergeSort()}}>MERGE SORT</button>
        <button className="nav-btn" id = "bead-sort" onClick = {()=>{this.beadSort()}}>BEAD SORT</button>
        <button className="nav-btn" id = "heap-sort" onClick = {()=>{this.heapSort()}}>HEAP SORT</button>
        <button className="nav-btn" id = "radix-sort" onClick = {()=>{this.radixSort()}}>RADIX SORT</button>
    </div>
</div>

我已经设置了CSS,以便当用户“悬停”在按钮“ PICK A SORT:”上时,列表可见。

但是,单击任何按钮时,除非用户将光标移出,否则下拉列表将保持可见,因为光标仍悬停在列表上方。

单击下拉菜单中的按钮后,是否可以隐藏列表?

这是我的CSS:

.dropdown {
    position: relative;
    display: inline-block;
}

.dropdown-content {
    display: none;
    position: absolute;
    background-color: rgba(255, 255, 255, 0.8);
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
    z-index: 1;
}

.dropdown-content .nav-btn{
    display: block;
    text-align: center;
    width: 100%;
    margin: 0 auto;
}

.dropdown:hover .dropdown-content {
    display: block;
}

这是现场website,您可以在其中查看问题。任何帮助将不胜感激!

2 个答案:

答案 0 :(得分:0)

您可以在onclick函数的.dropdown容器中添加一个clicked类,然后添加以下CSS:

.dropdown.clicked:hover .dropdown-content {
    display: none;
}

然后,您必须在某个时候删除clicked类,以使悬停效果再次起作用。

答案 1 :(得分:0)

您可以使父节点样式不显示onclick事件。

<button className="nav-btn" id = "bubble-sort" onClick = {()=>{this.bubbleSort()}; this.parentNode.style.display = 'none';}>BUBBLE SORT</button>

或者您可以使用一个通用函数来调用它,这将使parentNode像下面一样不显示

let displayNone = (el) => el.parentNode.style.display = 'none';

<button className="nav-btn" id = "bubble-sort" onClick = {()=>{ this.bubbleSort()};  displayNone(this); }>BUBBLE SORT</button>