我读过这个: Woocommerce get next / previous product
并尝试了这个:
<?php previous_post_link('%link', 'Previous in category', TRUE); ?>
并且他们中的任何一个都在woocommerce产品类别下工作,任何想法?
提前致谢!
答案 0 :(得分:10)
<?php previous_post_link_product('%link', '« Anterior: %title', true); ?>
<?php next_post_link_product('%link', 'Siguiente: %title »', true); ?>
在您的文件中,yourtheme / functions.php添加这些功能
function next_post_link_product($format='%link »', $link='%title', $in_same_cat = false, $excluded_categories = '') {
adjacent_post_link_product($format, $link, $in_same_cat, $excluded_categories, false);
}
function previous_post_link_product($format='« %link', $link='%title', $in_same_cat = false, $excluded_categories = '') {
adjacent_post_link_product($format, $link, $in_same_cat, $excluded_categories, true);
}
function adjacent_post_link_product( $format, $link, $in_same_cat = false, $excluded_categories = '', $previous = true ) {
if ( $previous && is_attachment() )
$post = get_post( get_post()->post_parent );
else
$post = get_adjacent_post_product( $in_same_cat, $excluded_categories, $previous );
if ( ! $post ) {
$output = '';
} else {
$title = $post->post_title;
if ( empty( $post->post_title ) )
$title = $previous ? __( 'Previous Post' ) : __( 'Next Post' );
$title = apply_filters( 'the_title', $title, $post->ID );
$date = mysql2date( get_option( 'date_format' ), $post->post_date );
$rel = $previous ? 'prev' : 'next';
$string = '<a href="' . get_permalink( $post ) . '" rel="'.$rel.'">';
$inlink = str_replace( '%title', $title, $link );
$inlink = str_replace( '%date', $date, $inlink );
$inlink = $string . $inlink . '</a>';
$output = str_replace( '%link', $inlink, $format );
}
$adjacent = $previous ? 'previous' : 'next';
echo apply_filters( "{$adjacent}_post_link", $output, $format, $link, $post );
}
function get_adjacent_post_product( $in_same_cat = false, $excluded_categories = '', $previous = true ) {
global $wpdb;
if ( ! $post = get_post() )
return null;
$current_post_date = $post->post_date;
$join = '';
$posts_in_ex_cats_sql = '';
if ( $in_same_cat || ! empty( $excluded_categories ) ) {
$join = " INNER JOIN $wpdb->term_relationships AS tr ON p.ID = tr.object_id INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id";
if ( $in_same_cat ) {
if ( ! is_object_in_taxonomy( $post->post_type, 'product_cat' ) )
return '';
$cat_array = wp_get_object_terms($post->ID, 'product_cat', array('fields' => 'ids'));
if ( ! $cat_array || is_wp_error( $cat_array ) )
return '';
$join .= " AND tt.taxonomy = 'product_cat' AND tt.term_id IN (" . implode(',', $cat_array) . ")";
}
$posts_in_ex_cats_sql = "AND tt.taxonomy = 'product_cat'";
if ( ! empty( $excluded_categories ) ) {
if ( ! is_array( $excluded_categories ) ) {
// back-compat, $excluded_categories used to be IDs separated by " and "
if ( strpos( $excluded_categories, ' and ' ) !== false ) {
_deprecated_argument( __FUNCTION__, '3.3', sprintf( __( 'Use commas instead of %s to separate excluded categories.' ), "'and'" ) );
$excluded_categories = explode( ' and ', $excluded_categories );
} else {
$excluded_categories = explode( ',', $excluded_categories );
}
}
$excluded_categories = array_map( 'intval', $excluded_categories );
if ( ! empty( $cat_array ) ) {
$excluded_categories = array_diff($excluded_categories, $cat_array);
$posts_in_ex_cats_sql = '';
}
if ( !empty($excluded_categories) ) {
$posts_in_ex_cats_sql = " AND tt.taxonomy = 'product_cat' AND tt.term_id NOT IN (" . implode($excluded_categories, ',') . ')';
}
}
}
$adjacent = $previous ? 'previous' : 'next';
$op = $previous ? '<' : '>';
$order = $previous ? 'DESC' : 'ASC';
$join = apply_filters( "get_{$adjacent}_post_join", $join, $in_same_cat, $excluded_categories );
$where = apply_filters( "get_{$adjacent}_post_where", $wpdb->prepare("WHERE p.post_date $op %s AND p.post_type = %s AND p.post_status = 'publish' $posts_in_ex_cats_sql", $current_post_date, $post->post_type), $in_same_cat, $excluded_categories );
$sort = apply_filters( "get_{$adjacent}_post_sort", "ORDER BY p.post_date $order LIMIT 1" );
$query = "SELECT p.id FROM $wpdb->posts AS p $join $where $sort";
$query_key = 'adjacent_post_' . md5($query);
$result = wp_cache_get($query_key, 'counts');
if ( false !== $result ) {
if ( $result )
$result = get_post( $result );
return $result;
}
$result = $wpdb->get_var( $query );
if ( null === $result )
$result = '';
wp_cache_set($query_key, $result, 'counts');
if ( $result )
$result = get_post( $result );
return $result;
}
答案 1 :(得分:1)
示例强>:
<?php previous_post_link( 'Previous: %link', '%title', true, '', 'product_cat' ); ?>
<?php next_post_link( 'Next: %link', '%title', true, '', 'product_cat' ); ?>
<强>解释强>:
使用WordPress'previous_post_link
或next_post_link
即可。事实上,你几乎就在那里。
除了将true
设置为第三个参数($ in_same_term)之外,还要确保将分类名称作为最后一个参数传递($ taxonomy)。对于WooCommerce,默认产品类别为product_cat
。
有一点需要注意,这些功能将获得与分配给当前产品的任何条款相匹配的下一个/上一个产品。通过将术语id(s)作为第四个参数($ exclude_terms)传递,可以排除术语。
<强>参考强>:
https://developer.wordpress.org/reference/functions/previous_post_link/ https://developer.wordpress.org/reference/functions/next_post_link/
<?php previous_post_link( $format, $link, $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ); ?>
<?php next_post_link( $format, $link, $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ); ?>
答案 2 :(得分:1)
但是,它假定产品是按post_date排序的。通常,menu_order应具有更高的排序优先级。
所以我改变了:
$current_post_date = $post->post_date;
分为:
$current_post_menu_order = $post->menu_order;
和$在哪里使用p.menu_order / $ current_post_menu_order:
$where = apply_filters( "get_{$adjacent}_post_where",
$wpdb->prepare("WHERE p.menu_order $op %s AND p.post_type = %s AND p.post_status = 'publish' $posts_in_ex_cats_sql",
$current_post_menu_order, $post->post_type), $in_same_cat, $excluded_categories );