如何使用jQuery创建过滤器控件?

胶合板

我正在尝试创建一个过滤器控件,但是它不能正常工作。

<div class="panel-filter-wrapper"><div class="panel-filter" data-filter-property="">
    <div class="panel-selected-filter">
        <span class="selected-filter-name">All</span>
        <span class="caret caret-down"></span>
    </div>
    <ul>
        <li data-value="*" data-param="role" class="selected">All</li>
        <li data-value="admin" data-param="role" class="">Admins</li>
        <li data-value="client" data-param="role">Clients</li>
        <li data-value="agent" data-param="role">Agents</li> 
    </ul>

CSS代码:

.panel-filter-wrapper {
 display: inline-block;
}
.panel-filter {
display: inline-block;
cursor: pointer;
position: relative;
color: #999;
}
.panel-filter .panel-selected-filter {
padding: 2px 19px 2px 10px;
border: 1px solid transparent;
position: relative;
z-index: 1;
}
.panel-filter:hover,
.panel-filter.active {
color: #444;
}
.panel-filter:hover .panel-selected-filter,
.panel-filter.active .panel-selected-filter {
 border: 1px solid #ccc;
 background: #fff;
}
.panel-filter:hover .caret,
.panel-filter.active .caret {
 display: inline-block;
}
.panel-filter.active .panel-selected-filter {
 border-bottom-width: 0;
}
.panel-filter.active ul {
display: block;
}
.panel-filter ul {
list-style: none;
display: none;
position: absolute;
border: 1px solid #ccc;
top: 24px;
left: 0;
margin: 0;
min-width: 100%;
z-index: 0;
background: #fff;
font-size: 13px;
border-radius: 2px;
-webkit-box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
border: 1px solid rgba(0, 0, 0, 0.1);
}
.panel-filter li {
padding: 5px 15px;
white-space: nowrap;
color: #333;
}
.panel-filter li:first-child {
border-top: none;
}
.panel-filter li:hover {
background-color: #f2f4f8 !important;
color: #181a1c;
}
.panel-filter li.selected {
font-weight: bold;
}
.panel-filter .caret {
display: none;
position: absolute;
right: 5px;
top: 9px;
}

.caret {
display: inline-block;
width: 0;
height: 0;
vertical-align: top;
border-bottom: 4px solid transparent;
border-top: 4px solid transparent;
border-right: 4px solid transparent;
border-left: 4px solid black;
content: "";
}
.caret,
.caret-down {
border-bottom: 4px solid transparent;
border-top: 4px solid black;
border-right: 4px solid transparent;
border-left: 4px solid transparent;
}

该代码示例在JSfiffle上问题是,jQuery无法处理click事件,并且不会显示项目列表。该控件应看起来(表现为):

在此处输入图片说明

阿曼·维迪

试试这个,它应该可以正常工作。工作小提琴

jQuery的:

$(document).ready(function(){
     $(".panel-selected-filter").click(function() { // show the dropdown list
         $('.panel-filter > ul').show();
     });

     $('.panel-filter > ul > li').click(function() {  // select and hide the the list
         $('.selected-filter-name').text($(this).text());
         $('.panel-filter > ul').hide();
     });

     $(document).click(function(e){           // hide list if clicked outside
         if($(e.target).is('.panel-selected-filter, .panel-selected-filter *'))return;
             $('.panel-filter > ul').hide();
     });
});

并且我添加了填充:0px; 在您的CSS类中,如下所示:

CSS:

.panel-filter ul {
    background: none repeat scroll 0 0 #fff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 2px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
    display: none;
    font-size: 13px;
    left: 0;
    list-style: none outside none;
    margin: 0;
    min-width: 100%;
    padding: 0;          /* added to align li's to the left*/
    position: absolute;
    top: 24px;
    z-index: 0;
}

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

如何使用引导程序和jQuery创建过滤器

来自分类Dev

如何使用Linq创建过滤器?

来自分类Dev

如何使用Jquery过滤器?

来自分类Dev

如何为jQuery中的项目列表创建过滤器?

来自分类Dev

使用jQuery为表中的li创建过滤器

来自分类Dev

如何使用jQuery为表格创建下拉列表过滤器?

来自分类Dev

如何使用PHP和MySQL创建搜索“过滤器”

来自分类Dev

如何过滤数据过滤器jQuery

来自分类Dev

如何使用jQuery / JavaScript的多个过滤器列表

来自分类Dev

如何使用jQuery制作下拉列表过滤器

来自分类Dev

使用Gmail API创建过滤器

来自分类常见问题

如何使用Docker图像过滤器

来自分类Dev

如何使用rxjs中的过滤器

来自分类Dev

如何使用SaveFileDialog的过滤器

来自分类Dev

如何使用javascript过滤器功能

来自分类Dev

如何使用ffmpeg removelogo过滤器

来自分类Dev

DirectShow示例过滤器:如何使用?

来自分类Dev

如何为JQuery tablesorter插件的过滤器小部件创建工具提示?

来自分类Dev

ngGrid如何在多个列(例如Excel数据过滤器)上创建过滤器?

来自分类Dev

如何在 angular2 中创建独特的过滤器过滤器组件

来自分类Dev

创建过滤器功能

来自分类Dev

Google控件类别过滤器

来自分类Dev

如何使用基本适配器在android中创建自定义过滤器?

来自分类Dev

在Angular JS中,当对ng-options使用select过滤器时。如何创建“全部”选项?

来自分类Dev

如何使用ActiveAdmin(Formtastic)创建动态填充的选择(下拉)过滤器

来自分类Dev

icCube-MDX-如何使用名为“ MONTH”的按钮在直方图中创建过滤器

来自分类Dev

如何通过使用带有谓词的某种过滤器来创建对象列表

来自分类Dev

如何使用Angular在日期范围内创建搜索过滤器?

来自分类Dev

如何使用从USERNAME()函数传入的单个值创建复杂的过滤器

Related 相关文章

  1. 1

    如何使用引导程序和jQuery创建过滤器

  2. 2

    如何使用Linq创建过滤器?

  3. 3

    如何使用Jquery过滤器?

  4. 4

    如何为jQuery中的项目列表创建过滤器?

  5. 5

    使用jQuery为表中的li创建过滤器

  6. 6

    如何使用jQuery为表格创建下拉列表过滤器?

  7. 7

    如何使用PHP和MySQL创建搜索“过滤器”

  8. 8

    如何过滤数据过滤器jQuery

  9. 9

    如何使用jQuery / JavaScript的多个过滤器列表

  10. 10

    如何使用jQuery制作下拉列表过滤器

  11. 11

    使用Gmail API创建过滤器

  12. 12

    如何使用Docker图像过滤器

  13. 13

    如何使用rxjs中的过滤器

  14. 14

    如何使用SaveFileDialog的过滤器

  15. 15

    如何使用javascript过滤器功能

  16. 16

    如何使用ffmpeg removelogo过滤器

  17. 17

    DirectShow示例过滤器:如何使用?

  18. 18

    如何为JQuery tablesorter插件的过滤器小部件创建工具提示?

  19. 19

    ngGrid如何在多个列(例如Excel数据过滤器)上创建过滤器?

  20. 20

    如何在 angular2 中创建独特的过滤器过滤器组件

  21. 21

    创建过滤器功能

  22. 22

    Google控件类别过滤器

  23. 23

    如何使用基本适配器在android中创建自定义过滤器?

  24. 24

    在Angular JS中,当对ng-options使用select过滤器时。如何创建“全部”选项?

  25. 25

    如何使用ActiveAdmin(Formtastic)创建动态填充的选择(下拉)过滤器

  26. 26

    icCube-MDX-如何使用名为“ MONTH”的按钮在直方图中创建过滤器

  27. 27

    如何通过使用带有谓词的某种过滤器来创建对象列表

  28. 28

    如何使用Angular在日期范围内创建搜索过滤器?

  29. 29

    如何使用从USERNAME()函数传入的单个值创建复杂的过滤器

热门标签

归档