繁体   English   中英

引导折叠面板上的过滤器

[英]Filter on bootstrap collapsion panels

我有一个带有Bootstrap折叠面板列表的页面。 我首先通过查询数据库中的内容来动态创建这些面板,请参见下面的代码:

<div class="panel-group" id="accordion">

<?php

        $all_emails = "SELECT * FROM sent_emails";

        if($result = mysqli_query($link, $all_emails)) {
            while($rows = $result->fetch_object()) {
                $db = $rows->timestamp;
                $timestamp = strtotime($db);

                echo '
                    <div class="panel panel-default m'.date("m", $timestamp).'">
                        <div class="panel-heading">
                            <h4 class="panel-title">
                                <a data-toggle="collapse" data-parent="#accordion" href="#collapse'.$rows->ai.'">
                                    #'.$rows->ai.' | Sent to: '.$rows->mail_to.' | Subject: '.$rows->mail_subject.' <span class="pull-right">| '.$rows->timestamp.' </span>
                                </a>
                            </h4>
                        </div>
                        <div id="collapse'.$rows->ai.'" class="panel-collapse collapse">
                            <div class="panel-body">
                                '.$rows->mail_message.'
                            </div>
                        </div>
                    </div>  
                ';

            }

            mysqli_free_result($result);
        }

?>

</div>

一切正常,但是我接下来要做的是添加一个过滤器,该过滤器仅显示其中具有特定类的面板。 如您在上面的代码中看到的,我创建了带有“ panel panel-default m('month')”类的div,它们都具有一个称为“ panel-group”的父div。

当我从下拉按钮中选择一个月时,如下所示,我将当月的值/ id带入jQuery作为过滤器的输入。

<div class="dropdown1">
    <button class="btn btn-default dropdown-toggle" type="button" id="dropdownMenu1" data-toggle="dropdown">
         Select month
         <span class="caret"></span>
    </button>
    <ul class="dropdown-menu" role="menu" aria-labelledby="dropdownMenu1" id="select1">
        <li value="january" id="m1" role="presentation"><a href="#">January</a></li>
        <li value="february" id="m2" role="presentation"><a href="#">February</a></li>
        <li value="march" id="m3" role="presentation"><a href="#">March</a></li>
        <li value="april" id="m4" role="presentation"><a href="#">April</a></li>
        <li value="may" id="m5" role="presentation"><a href="#">May</a></li>
        <li value="june" id="m6" role="presentation"><a href="#">June</a></li>
        <li value="july" id="m7" role="presentation"><a href="#">July</a></li>
        <li value="august" id="m8" role="presentation"><a href="#">August</a></li>
        <li value="september" id="m9" role="presentation"><a href="#">September</a></li>
        <li value="october" id="m10" role="presentation"><a href="#">October</a></li>
        <li value="november" id="m11" role="presentation"><a href="#">November</a></li>
        <li value="december" id="m12" role="presentation"><a href="#">December</a></li>
    </ul>
</div><!--/.dropdown1 -->

到目前为止,我有以下jQuery代码。 每个不具有该类的“ panel-group”的子div都必须隐藏(例如10月份)。

<script>
$(function(){
    $("#select1").on('click', 'li', function(){
        $("#dropdownMenu1").text($(this).text());
        $("#dropdownMenu1").val($(this).text());    

        $(".panel-group").show();

        $(".panel-group .panel.panel-default :not(."+this.id+")").hide();

    });
});

我一直在努力,并在互联网上搜索了可以满足我需要的答案,但到目前为止还没有运气:(

隐藏所有内容,然后显示正确的内容:

$(function(){
    $("#select1").on('click', 'li', function(){
        $("#dropdownMenu1").text($(this).text());
        $("#dropdownMenu1").val($(this).text());    

        $(".panel-group .panel").hide();

        $(".panel-group .panel.panel-default."+this.id).show();

    });
});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM