如何(如果存在)应用(Wordpress)元查询

时间:2017-01-28 15:59:38

标签: php mysql wordpress posts

我正在尝试在产品列表中应用过滤器。用户将使用前端的选择框,然后单击按钮以过滤产品。

每个产品都是自己的帖子,所以我使用WP_Query来获取帖子。例如,我想要所有产品颜色为“红色”,材料为“塑料”,品牌为“Bikon”。所以我用;

$color = "red";
$material = "plastic";
$brand = "Bikon";
$query = new WP_Query(array(
    'post_type'         => 'products',
    'posts_per_page'    =>  6,
    'post_status'       => 'publish',
    'meta_query'    => array(
        'relation'      => 'AND',
        array(
            'key'       => 'color',
            'value'     => $color,
            'compare'   => '='
        ),
        array(
            'key'       => 'material',
            'value'     => $material,
            'compare'   => '='
        ),
        array(
            'key'       => 'brand',
            'value'     => $brand,
            'compare'   => '='
        )
    )
));

如果设置了每个值,这将正常工作。但是如果只使用其中一个选择框,则其他两个值将为空,查询将不返回任何帖子。有没有办法说“如果设置了这个值,只在元查询中使用这个数组”?

1 个答案:

答案 0 :(得分:4)

您可以检查变量的定义并添加其他过滤(如果存在)

show