jQuery - 显示/隐藏搜索框

7
我已经写了一些jQuery代码,当单击一个div时,会滑动打开一个搜索框。基本上,单击时会显示一个最初隐藏的div,该div内部是一个搜索框和一个关闭按钮。这一切都很好地运行着。然而,无法正常工作的是关闭按钮。我的猜测是,关闭按钮不能隐藏那个div,因为它本身就在div里面。以下是我的代码,还有jsfiddle链接。

HTML

<ul class="tert-nav">
    <li><img alt="" border="0" src="images/icon-cart.png" width="16" height="16" /></li>
    <li><img alt="" border="0" src="images/icon-tickets.png" width="16" height="16" /></li>
    <li class="searchit">
        <img alt="" border="0" class="searchicon" src="images/icon-search.png" width="16" height="16" />
        <div class="searchbox">
            <img alt="" border="0" class="closesearch" src="images/icon-close.png" width="16" height="16" />
            <input placeholder="search..." type="text" />
            <input type="submit" value="" />
        </div>
    </li>
</ul>

jQuery

$(document).ready(function() {

// Search
$('ul.tert-nav li.searchit').click(function() {
    $(this).addClass('search');
    $('.searchbox').fadeIn();
    $('ul.tert-nav li img.searchicon').hide();
});

$('ul.tert-nav li.searchit img.closesearch').click(function() {
    $('.searchbox').hide();
    $('ul.tert-nav li').removeClass('search');
});

})

CSS

ul.tert-nav {
    float: right;
    position: absolute;
    margin: 0;
    padding: 0;
    right: 0;
    top: 0;
    list-style: none;
}

ul.tert-nav li {
    float: right;
    width: 26px;
    height: 28px;
    background: #3c3c3c;
    text-align: center;
    margin-left: 2px;
    cursor: pointer;
    transition: all .2s ease;
    -o-transition: all .2s ease;
    -moz-transition: all .2s ease;
    -webkit-transition: all .2s ease;
}

ul.tert-nav li:hover {
    background: #000;
}

ul.tert-nav .search {
    width: 246px;
    text-align: left;
    cursor: default;
}

ul.tert-nav .search:hover {
    background: #3c3c3c;
}

ul.tert-nav .searchbox {
    display: none;
    width: 100%;
}

ul.tert-nav .searchbox .closesearch {
    float: left;
    margin: 6px 4px 0px 4px;
    cursor: pointer;
}

ul.tert-nav .searchbox .closesearch:hover {
    opacity: 0.8;   
}

ul.tert-nav .searchbox input[type=text] {
    float: left;
    width: 184px;
    height: 24px;
    padding: 0px 0px 0px 10px;
    margin: 2px 0px 0px 0px;
    border: none;
    background: url(images/search-bg.png) no-repeat;
    outline: none;
}

ul.tert-nav .searchbox input[type=submit] {
    float: left;
    width: 26px;
    height: 24px;
    margin: 2px 0px 0px 0px;
    padding: 0px;
    border: none;
    background: url(images/search-btn.png) no-repeat;
    outline: none;
    cursor: pointer;
}

此外,这是一个初始状态和点击/打开状态的示例图,以便直观地了解我想要做什么。谢谢!

enter image description here

2个回答

8

由于关闭按钮位于.searchit框内,因此第一个处理程序在关闭处理程序之后也会被触发。在关闭处理程序期间停止点击事件的传播,它就可以正常工作:

$('ul.tert-nav li.searchit img.closesearch').click(function(e) {
    e.stopPropagation();
    $('.searchbox').hide();
    $('ul.tert-nav li').removeClass('search');
});

太好了!很有道理,我甚至试图停止传播,但我想我只是没有添加(e) :) - Trevan Hetzel

3
< p > stopPropagation()的替代方法是只让div在被点击时执行它的操作。

如果控件中有很多具有自己的单击事件的元素,并且您不想更新所有这些元素,或者如果您需要让单击事件传播但仍然希望能够在某些单击事件中进行区分,则此方法非常有用。

当然,在您特定的情况下,使用stopPropagation()会更容易实现。

$('ul.tert-nav li.searchit').click(function (event) {
        // Did the click originate from this?
        if(event.target !== this){
            // No, it wasn't. So we do nothing.
            return;
        }

        $(this).addClass('search');
        $('.searchbox').fadeIn();
        $('ul.tert-nav li img.searchicon').hide();
});

演示 - 验证点击事件的来源



网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接