【问题标题】:jQuery simple checkbox to hide and show divs (product filtering)用于隐藏和显示 div 的 jQuery 简单复选框(产品过滤)
【发布时间】:2012-09-24 18:47:30
【问题描述】:

我正在使用 jQuery 过滤页面上的产品项目(隐藏和显示 DIV) 我正在使用过滤器作为替代品,因为 PHP $_GET 有点过时,我们正试图通过 jQuery 来做到这一点。我使用 filter() 和 data 属性。

如何关闭除现有项目之外的当前复选框选择? 如何根据选择隐藏项目并在不隐藏时取消隐藏?

HTML

<input type="checkbox" id="drama" onClick="filterCategory(this.value)" value="drama" /> Drama<br />
<input type="checkbox" id="romance" onClick="filterCategory(this.value)" value="" /> Romance<br />
<input type="checkbox" id="horror" onClick="filterCategory(this.value)" value="horror" /> Horror<br />

<!--------------------->
<div class="products">
    <div class="productItem" data-price="250" data-category="horror">
        Scary Book
        <div class="productItemPrice"><span>&pound;250</span></div>
    </div>
    <div class="productItem" data-price="150" data-category="drama">
        Drama Poems
        <div class="productItemPrice"><span>&pound;150</span></div>
    </div>
    <div class="productItem" data-price="250" data-category="romance">
        Love Story
        <div class="productItemPrice"><span>&pound;250</span></div>
    </div>
    <div class="productItem" data-price="241" data-category="horror">
        Creep Book
        <div class="productItemPrice"><span>&pound;241</span></div>
    </div>
</div>
<!--------------------->

jQUERY

function filterCategory(id) {
    var pid=$(".productItem"); // Which product is it
    var checkid=$('#'+id); // The name of the checkbox form
    var cid=$(pid).data("category"); // The value of the checkbox form
    if ($(checkid).is(':checked')){
        $(pid).hide().filter(function () {var catId=$(this).data("category");return catId;}).show();
    } else {
        $(pid).show().filter(function () {var catId=$(this).data("category");return catId;}).show();
    }
}

CSS

.productItem{float:left;padding:5px;margin:5px;border:1px solid #eaeaea}
body{font-family:verdana}

JSFiddle

http://jsfiddle.net/RyZy8/

【问题讨论】:

    标签: jquery html custom-data-attribute


    【解决方案1】:

    您可以尝试使用类似的东西,

    首先去掉复选框上的onclick属性——使用jQuery绑定click事件:

    // bind to click
    $('input[type="checkbox"]').click(function() {
        // any checked
        if ($('input[type="checkbox"]:checked').length > 0) {
            // hide all
            $('.products >div').hide();
            // loop checked and display relavent div
            $('input[type="checkbox"]:checked').each(function() {
                $('.products >div[data-category=' + this.id + ']').show();
            });
        } else {
            // none checked - show all
            $('.products >div').show();
        }
    });​
    

    Working example here

    【讨论】:

    • 但这不会恢复列表。因此,单击显示恐怖的恐怖并再次单击它将再次显示列表。
    • @TheBlackBenzKid 添加了 if 语句
    猜你喜欢
    • 2012-05-19
    • 1970-01-01
    • 2011-05-26
    • 2016-01-20
    • 2019-09-16
    • 1970-01-01
    • 2013-05-27
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多