在选择框外单击时撤消选择选项

时间:2012-09-17 05:40:12

标签: jquery html css

我使用followig html / css和jQuery创建了一个自定义选择框。

div.selectBox {
    position:relative;
    display:inline-block;
    cursor:default;
    text-align:left;
    line-height:30px;
    clear:both;
    color:#888;
}
span.selected {
    width:167px;
    text-indent:20px;
    border:1px solid #ccc;
    border-right:none;
    border-top-left-radius:5px;
    border-bottom-left-radius:5px;
    background:#f6f6f6;
    overflow:hidden;
}
span.selectArrow {
    width:30px;
    border:1px solid #60abf8;
    border-top-right-radius:5px;
    border-bottom-right-radius:5px;
    text-align:center;
    font-size:20px;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -o-user-select: none;
    user-select: none;
    background:#4096ee;
}

span.selectArrow,span.selected {
    position:relative;
    float:left;
    height:30px;
    z-index:1;
}
div.selectOptions {
    position:absolute;
    top:28px;
    left:0;
    width:198px;
    border:1px solid #ccc;
    border-bottom-right-radius:5px;
    border-bottom-left-radius:5px;
    overflow:hidden;
    background:#f6f6f6;
    padding-top:2px;
    display:none;
}

span.selectOption {
    display:block;
    width:80%;
    line-height:20px;
    padding:5px 10%;
}

span.selectOption:hover {
    color:#f6f6f6;
    background:#4096ee;         
}

和jQuery:

$('div.selectBox').each(function(){
        $(this).children('span.selected').html($(this).children('div.selectOptions').children('span.selectOption:first').html());
    $(this).attr('value',$(this).children('div.selectOptions').children('span.selectOption:first').attr('value'));

    $(this).children('span.selected,span.selectArrow').click(function(){
        if($(this).parent().children('div.selectOptions').css('display') == 'none'){
            $(this).parent().children('div.selectOptions').css('display','block');
        }
        else
        {
            $(this).parent().children('div.selectOptions').css('display','none');
        }
    });

    $(this).find('span.selectOption').click(function(){
        $(this).parent().css('display','none');
        $(this).closest('div.selectBox').attr('value',$(this).attr('value'));
        $(this).parent().siblings('span.selected').html($(this).html());
    });
});

但是当我们点击选择框中的箭头时,会出现列表。但只有当我们点击相同的箭头时它才会关闭。当我点击页面的任何其他部分时,如何实现要关闭的列表?

HTML

<div class='selectBox'>
    <span class='selected'></span>
    <span class='selectArrow'>&#9660</span>
    <div class="selectOptions" >
        <span class="selectOption" value="Option 1">Option 1</span>
        <span class="selectOption" value="Option 2">Option 2</span>
        <span class="selectOption" value="Option 3">Option 3</span>
    </div>
</div>

2 个答案:

答案 0 :(得分:3)

使用文档点击隐藏.selectOptions

$(document).unbind('click');
$(document).click(function(event){
    if($(event.target).closest('div.selectBox').length == 0) {
         $('.selectOptions').hide();                
    }
});

工作示例:http://jsfiddle.net/FBuKG/

答案 1 :(得分:0)

$('body').click(function() {
    if($('div.selectOptions').css('display') != 'none'){
        $('div.selectOptions').css('display','none');
    }
});