0

我创建了一个卡片数据库,您可以在此处查看http://hearthable.com/cards。我通过自定义帖子类型在 wordpress 中做到了这一点。我有 400 多张卡片。我还有 4 个自定义帖子类型类别/分类法。

我的自定义帖子类型名为“cards”,4 个自定义分类是“cards-type”、“cards-rarity”和“cards-class”、“cards-race”。

我想添加一个过滤器功能,我的用户可以单击其中一个、2 或 3 个类别旁边的复选框,并根据他们的选择过滤卡片。

我一直在寻找,在这方面找不到任何东西,所以一点帮助将不胜感激。谢谢你。

4

1 回答 1

1

我做了一个简单的例子,只是为了向你展示过滤器是如何工作的。它可以改进并且可以通过其他方式完成。

你必须创建一个表单并设置一个页面(我已经硬编码,你可以做得更好)

<form action="/sample-page/" method="post">

    <?php 
        wp_dropdown_categories( array(
        'show_option_all'    => 'All',
        'show_option_none'   => 'None',
        'show_count'         => 0,
        'hide_empty'         => 0, 
        'exclude'            => '',
        'echo'               => 1,
        'name'               => 'cards-type',
        'id'                 => '',
        'class'              => 'postform',
        'taxonomy'           => 'cards-type',
        'hide_if_empty'      => false,
    ) );

    wp_dropdown_categories( array(
        'show_option_all'    => 'All',
        'show_option_none'   => 'None',
        'show_count'         => 0,
        'hide_empty'         => 0, 
        'exclude'            => '',
        'echo'               => 1,
        'name'               => 'cards-rarity',
        'id'                 => '',
        'class'              => 'postform',
        'taxonomy'           => 'cards-rarity',
        'hide_if_empty'      => false,
    ) );

    ?>

    <button type="submit">Go</button>
</form>

在您设置的页面中,您必须获取数据并将其转换为数组WP_Query

    $args = array(
        'post_type' => 'cards', 
    );

    $item = array();
    $list = array();

    if ( $_POST ) {
        foreach( $_POST as $key => $value ) {
            if( !empty($value) ) {
                $item['taxonomy'] = htmlspecialchars($key);
                $item['terms'] = htmlspecialchars($value);
                $item['field'] = 'id';
                $list[] = $item;
            }
            $cleanArray = array_merge(array('relation' => 'AND'), $list);
        }  

        $args['tax_query'] = $cleanArray;   
    }

    $loooop = new WP_Query( $args );

您使用循环来迭代结果

if ( $loooop->have_posts() ) : while ( $loooop->have_posts() ) : $loooop->the_post();
    the_title();
endwhile;
wp_reset_postdata();

对不起英语不好

于 2013-11-11T23:56:12.897 回答