我有一个 WooCommerce 网站,当产品标签存档页面有 0 个“库存”产品可用时,需要从产品标签云中隐藏产品标签。
下面的代码显示了我当前的进度,我将在取得更多进展时进行更新。 我相信这段代码可以修改为运行检查并删除“显示计数”值小于 1 的任何结果,这将回答这个问题。此外,隐藏结果需要 302 重定向到顶级“商店”页面,同时暂时隐藏:
/* TURN PRODUCT TAG CLOUD INTO ALPHABETICAL LIST WITH TAG TOTALS COUNT VISIBLE */
function woocommerce_product_tag_cloud_widget_filter($args) {
$args = array(
'smallest' => 14,
'largest' => 14,
'format' => 'list',
'taxonomy' => 'product_tag',
'unit' => 'px',
'show_count' => 1,
'number' => 0,
);
echo "<div style='padding-left: 20px;'>";
return $args;
echo "</div>";
}
add_filter('woocommerce_product_tag_cloud_widget_args', 'woocommerce_product_tag_cloud_widget_filter');
我还有这段代码,可以用作第二种方法。注释显示了缺少的内容:
/* REMOVE PRODUCT TAGS FROM THE PRODUCT TAG CLOUD WHEN THEY HAVE LESS THAN 1 IN-STOCK RESULTS */
function filter_woocommerce_product_tag_cloud_widget_args( $array ) {
$c = // check to see how many in stock products a product tag archive has
if($c <= 1){
// show array excluding empty product tag archives
}else{
return $array;
}
}
add_filter( 'woocommerce_product_tag_cloud_widget_args', 'filter_woocommerce_product_tag_cloud_widget_args', 10, 1 );
我有以下资源可以提供帮助,但是我缺乏 PHP 知识意味着我无法将这些不同的代码片段放入单个函数中以实现我想要的结果。
我有来自 How to remove empty product tags from the tag cloud on woocommerce 的这段代码 我之前问题的答案代码,该代码隐藏了标签云中的所有空产品标签(但它不考虑库存可用性,因此仍会显示包含 0 个“库存”产品的产品标签)。
下面我还有其他一些代码片段,它们可能有助于也可能没有帮助最终的解决方案。
此代码隐藏了整个产品标签云。
add_action( 'widgets_init', 'misha_remove_product_tag_cloud_widget' );
function misha_remove_product_tag_cloud_widget(){
unregister_widget('WC_Widget_Product_Tag_Cloud');
}
此代码隐藏具有 0 个“库存”产品的所有类别。
add_filter( 'wp_get_nav_menu_items', 'nav_remove_empty_category_menu_item', 10, 3 );
function nav_remove_empty_category_menu_item ( $items, $menu, $args ) {
global $wpdb;
$nopost = $wpdb->get_col( "SELECT term_taxonomy_id FROM $wpdb->term_taxonomy WHERE count = 0" );
foreach ( $items as $key => $item ) {
if ( ( 'taxonomy' == $item->type ) && ( in_array( $item->object_id, $nopost ) ) ) {
unset( $items[$key] );
}
}
return $items;
}
我尝试将上述代码片段的各个元素放在一起来创建一个实现我的目标的函数,但我缺乏能力意味着我没有任何东西可以正确工作,因此我需要额外的帮助。
最佳答案
我已经设法拼凑出这个问题的以下解决方案,该解决方案实际上更进一步,并添加了一些其他很酷的功能,我试图在注释代码中解释这些功能。
如果有人对此代码有任何反馈、补充、评论或疑问,请与我们联系!我将尝试扩展此代码,以便它还可以通过仅显示与网站内用户位置相关的标签并从这些级别中删除所有不相关的标签来兼作细化功能 - 欢迎任何建议!
特别感谢 Facebook 上的 Md. Mehedi Hasan 帮助编写中间部分的代码,以从前端隐藏产品标签存档页面。
/* TURN PRODUCT TAG CLOUD INTO ALPHABETICAL LIST WITH TAG TOTALS COUNT VISIBLE */
function woocommerce_product_tag_cloud_widget_filter($args) {
$args = array(
'smallest' => 14,
'largest' => 14,
'format' => 'list',
'taxonomy' => 'product_tag',
'unit' => 'px',
'show_count' => 1,
'number' => 0,
);
echo "<div style='padding-left: 20px; min-height: 50px; max-height: 400px; overflow: auto;'>";
return $args;
echo "</div>";
}
add_filter('woocommerce_product_tag_cloud_widget_args', 'woocommerce_product_tag_cloud_widget_filter');
/* HIDE PRODUCT TAG ARCHIVE PAGES WHEN THEY HAVE NO 'IN STOCK' PRODUCTS */
function hide_empty_tags( $terms, $taxonomies) {
$new_terms = array();
if ( in_array( 'product_tag', $taxonomies ) && ! is_admin() ) {
foreach ( $terms as $key => $term ) {
if ($term->count >0){
$new_terms[] = $term;
}
}
$terms = $new_terms;
}
return $terms;
}
add_filter( 'get_terms', 'hide_empty_tags', 10, 3 );
/* REDIRECTS TO SHOP IF THERE ARE NO 'IN STOCK' PRODUCTS IN THE PRODUCT TAG ARCHIVE PAGE */
function redirect_to_shop(){
global $wp_query;
if( is_woocommerce() && $wp_query->post_count == 0 ){
the_post();
$post_url = "/shop";
wp_safe_redirect($post_url , 302 );
exit;
}
}
add_action('template_redirect', 'redirect_to_shop');
关于php - WooCommerce - 当标签云中没有 'in stock' 产品时如何隐藏产品标签,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64139113/