#php #wordpress #woocommerce
#php #wordpress #woocommerce
Вопрос:
Я пытаюсь изменить стиль своей темы для слайдеров, не используя плагины (поскольку структура отдельной страницы продукта нарушена). Я использую следующие строки для стиля woocommerce, но опция масштабирования отключена, и галерея товаров не работает.
Сначала я использую следующие строки в product-image.php
.
поскольку я хочу разделить страницу на две колонки. и, как вы видите на следующем рисунке, здесь нет опции слайдера и масштабирования.
также я ищу, и многие говорили, что с помощью add_theme_support, и я использовал их для function.php
:
add_theme_support( 'wp-product-gallery-zoom' );
add_theme_support( 'wp-product-gallery-lightbox' );
add_theme_support( 'wp-product-gallery-slider' );
но это не работает. не могли бы вы дать мне несколько советов или ссылок для решения моей проблемы.
<?php
/**
* Single Product Image
*
* This template can be overridden by copying it to yourtheme/woocommerce/single-product/product-image.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/
* @package WooCommerceTemplates
* @version 3.5.1
*/
defined( 'ABSPATH' ) || exit;
// Note: `wc_get_gallery_image_html` was added in WC 3.3.2 and did not exist prior. This check protects against theme overrides being used on older versions of WC.
if ( ! function_exists( 'wc_get_gallery_image_html' ) ) {
return;
}
global $product;
$columns = apply_filters( 'woocommerce_product_thumbnails_columns', 8 );
$post_thumbnail_id = $product->get_image_id();
$wrapper_classes = apply_filters(
'woocommerce_single_product_image_gallery_classes',
array(
'woocommerce-product-gallery',
'woocommerce-product-gallery--' . ( $product->get_image_id() ? 'with-images' : 'without-images' ),
'woocommerce-product-gallery--columns-' . absint( $columns ),
'images',
)
);
?>
<div class="row">
<div class="col-md-6 pr-5 content-section <?php echo esc_attr( implode( ' ', array_map( 'sanitize_html_class', $wrapper_classes ) ) ); ?>" data-columns="<?php echo esc_attr( $columns ); ?>" style="opacity: 0; transition: opacity .25s ease-in-out;">
<br>
<figure class="woocommerce-product-gallery__wrapper">
<div class="row">
<?php
if ( $product->get_image_id() ) {
$html = wc_get_gallery_image_html( $post_thumbnail_id, true );
} else {
$html = '<div class="woocommerce-product-gallery__image--placeholder">';
$html .= sprintf( '
<img src="%s" alt="%s" class="wp-post-image" />
',
esc_url( wc_placeholder_img_src( 'woocommerce_single' ) ), esc_html__( 'Awaiting product image', 'woocommerce' ) );
$html .= '</div>';
}
echo apply_filters( 'woocommerce_single_product_image_thumbnail_html', $html, $post_thumbnail_id ); // phpcs:disable WordPress.XSS.EscapeOutput.OutputNotEscaped
do_action( 'woocommerce_product_thumbnails' );
?>
</div>
</figure>
<br>
</div>