向存档页面上的所有WooCommerce产品添加自定义ID属性

时间:2018-03-14 作者:KYSSE

我注意到每个产品都有一个自定义类,如class="post-396516" 然而,我也希望这个值是一个ID属性,而不仅仅是所有产品上的一个类<li>\'woocommerce归档页中的。

有没有一个功能可以添加到我的孩子主题中来实现这一点?

谢谢你的帮助!

enter image description here

1 个回复
最合适的回答,由SO网友:Dave Romsey 整理而成

复制/woocommerce/templates/content-product.php/yourtheme/woocommerce/content-product.php 并根据需要进行修改。

在这种情况下,我们可以更改开口<li> 标签来自:

<li <?php post_class(); ?>>
对此:

<li <?php post_class(); ?> id="<?php echo esc_attr( \'post-\' . get_the_ID() ); ?>">
更新的content-product.php 文件如下所示:

<?php
/**
 * The template for displaying product content within loops
 *
 * This template can be overridden by copying it to yourtheme/woocommerce/content-product.php.
 *
 * HOWEVER, on occasion WooCommerce will need to update template files and you
 * (the theme developer) will need to copy the new files to your theme to
 * maintain compatibility. We try to do this as little as possible, but it does
 * happen. When this occurs the version of the template file will be bumped and
 * the readme will list any important changes.
 *
 * @see     https://docs.woocommerce.com/document/template-structure/
 * @author  WooThemes
 * @package WooCommerce/Templates
 * @version 3.0.0
 */

if ( ! defined( \'ABSPATH\' ) ) {
    exit; // Exit if accessed directly
}

global $product;

// Ensure visibility
if ( empty( $product ) || ! $product->is_visible() ) {
    return;
}
?>
<li <?php post_class(); ?> id="<?php echo esc_attr( \'post-\' . get_the_ID() ); ?>">
    <?php
    /**
     * woocommerce_before_shop_loop_item hook.
     *
     * @hooked woocommerce_template_loop_product_link_open - 10
     */
    do_action( \'woocommerce_before_shop_loop_item\' );

    /**
     * woocommerce_before_shop_loop_item_title hook.
     *
     * @hooked woocommerce_show_product_loop_sale_flash - 10
     * @hooked woocommerce_template_loop_product_thumbnail - 10
     */
    do_action( \'woocommerce_before_shop_loop_item_title\' );

    /**
     * woocommerce_shop_loop_item_title hook.
     *
     * @hooked woocommerce_template_loop_product_title - 10
     */
    do_action( \'woocommerce_shop_loop_item_title\' );

    /**
     * woocommerce_after_shop_loop_item_title hook.
     *
     * @hooked woocommerce_template_loop_rating - 5
     * @hooked woocommerce_template_loop_price - 10
     */
    do_action( \'woocommerce_after_shop_loop_item_title\' );

    /**
     * woocommerce_after_shop_loop_item hook.
     *
     * @hooked woocommerce_template_loop_product_link_close - 5
     * @hooked woocommerce_template_loop_add_to_cart - 10
     */
    do_action( \'woocommerce_after_shop_loop_item\' );
    ?>
</li>

结束