jquery - 在选择框外部单击时缩回选择选项

标签 jquery html css

我使用以下 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>

最佳答案

使用文档单击隐藏.selectOptions:

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

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

关于jquery - 在选择框外部单击时缩回选择选项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12453647/

相关文章:

javascript - 在事件方法中调用 JS 函数

javascript - 选择单选按钮时隐藏特定的表单输入

html - 水平居中 iframe

javascript - 循环图像动画

html - 在产品构建中找不到 Font Awesome 相对文件路径

javascript - 无法开始工作 MagicSuggest.js

javascript - 图表宽度没有渲染好

html - 使用浏览器窗口调整内容大小

javascript - 如何让一个div滚动到底部

html - 填充盒子所有空白空间的 float div