Woocommerce使用数组隐藏商店中的多个类别

时间:2014-04-26 16:25:39

标签: php arrays woocommerce categories webshop

以下代码与19一起工作正常,因为它是从woocommerce网站复制的。不幸的是,我无法让它用$ producten取代19,以便$ producten包含一个包含所有类别的数组。

$ producten包含需要隐藏并在数据库中定义的多个类别。是否可能我想做什么以及如何做?

$userid = get_current_user_id();

$result = mysql_query("SELECT productID FROM bestellingen WHERE userID='$userid'");
$producten = array();
while($row = mysql_fetch_array($result)){
array_push($producten, $row['productID']);
}

add_action( 'pre_get_posts', 'custom_pre_get_posts_query' );

function custom_pre_get_posts_query( $q ) {

if ( ! $q->is_main_query() ) return;
if ( ! $q->is_post_type_archive() ) return;

if ( ! is_admin() && is_shop() ) {

    $q->set( 'tax_query', array(array(
        'taxonomy' => 'product_cat',
        'field' => 'slug',
        'terms' => array( 19 ), // de categorienummers
        'operator' => 'NOT IN'
    )));

}

remove_action( 'pre_get_posts', 'custom_pre_get_posts_query' );

}

提前致谢!

1 个答案:

答案 0 :(得分:0)

使用类似的会话解决:

$result = mysql_query("SELECT productID FROM bestellingen WHERE userID='$userid'");
$producten = array();
while($row = mysql_fetch_array($result)){
array_push($producten, $row['productID']);
}
$_SESSION['PRODUCTEN'] = $producten;

add_action( 'pre_get_posts', 'custom_pre_get_posts_query' );

function custom_pre_get_posts_query( $q ) {



if ( ! $q->is_main_query() ) return;
if ( ! $q->is_post_type_archive() ) return;

if ( ! is_admin() && is_shop() ) {

    $q->set( 'tax_query', array(array(
        'taxonomy' => 'product_cat',
        'field' => 'slug',
        'terms' => $_SESSION['PRODUCTEN'], // Don't display products in the knives category on the shop page
        'operator' => 'NOT IN'
    )));


}

    unset($_SESSION['PRODUCTEN']);
remove_action( 'pre_get_posts', 'custom_pre_get_posts_query' );
}