Как вывести выпадающий список вариаций товара на странице магазина WooCommerce

Один из наших читателей спросил, возможно ли вывести выпадающий список выбора вариативного товара на странице магазина, чтобы покупатель мог закинуть в корзину вариативный товар без необходимости открывать страницу товара. В этой статье мы поделимся с вами таким решением.

Идея достаточно простая. Когда вы посещаете страницу магазина, код проверяет типа товара, и если он совпадает с вариативным, тогда кнопка «Выбрать опции» заменяется на стандартную для вариативных товаров кнопку добавления в корзину. Другими словами, он отображает выпадающий список свойств товара, а затем добавляет кнопку «В корзину» для всех вариативных товаров на странице магазина.

woocommerce-dropdowns-selects-on-archive-page[1]

Если вы решили воспользоваться этим сниппетом, тогда просто поместите его в файл functions.php своей темы:

<?php
// Выводим выпадающий список вариаций на странице магазина для вариативных товаров
 add_filter( 'woocommerce_loop_add_to_cart_link', 'woo_display_variation_dropdown_on_shop_page' );

 function woo_display_variation_dropdown_on_shop_page() {

 	global $product;

	if( $product->is_type( 'variable' )) {

	$attribute_keys = array_keys( $product->get_attributes() );
	?>

	<form class="variations_form cart" method="post" enctype='multipart/form-data' data-product_id="<?php echo absint( $product->id ); ?>" data-product_variations="<?php echo htmlspecialchars( json_encode( $product->get_available_variations() ) ) ?>">
		<?php do_action( 'woocommerce_before_variations_form' ); ?>

		<?php if ( empty( $product->get_available_variations() ) && false !== $product->get_available_variations() ) : ?>
			<p class="stock out-of-stock"><?php _e( 'This product is currently out of stock and unavailable.', 'woocommerce' ); ?></p>
		<?php else : ?>
			<table class="variations" cellspacing="0">
				<tbody>
					<?php foreach ( $product->get_attributes() as $attribute_name => $options ) : ?>
						<tr>
							<td class="label"><label for="<?php echo sanitize_title( $attribute_name ); ?>"><?php echo wc_attribute_label( $attribute_name ); ?></label></td>
							<td class="value">
								<?php
									$selected = isset( $_REQUEST[ 'attribute_' . sanitize_title( $attribute_name ) ] ) ? wc_clean( urldecode( $_REQUEST[ 'attribute_' . sanitize_title( $attribute_name ) ] ) ) : $product->get_variation_default_attribute( $attribute_name );
									wc_dropdown_variation_attribute_options( array( 'options' => $options, 'attribute' => $attribute_name, 'product' => $product, 'selected' => $selected ) );
									echo end( $attribute_keys ) === $attribute_name ? apply_filters( 'woocommerce_reset_variations_link', '<a class="reset_variations" href="#">' . __( 'Clear', 'woocommerce' ) . '</a>' ) : '';
								?>
							</td>
						</tr>
					<?php endforeach;?>
				</tbody>
			</table>

			<?php do_action( 'woocommerce_before_add_to_cart_button' ); ?>

			<div class="single_variation_wrap">
				<?php
					do_action( 'woocommerce_before_single_variation' );

					do_action( 'woocommerce_single_variation' );

					do_action( 'woocommerce_after_single_variation' );
				?>
			</div>

			<?php do_action( 'woocommerce_after_add_to_cart_button' ); ?>
		<?php endif; ?>

		<?php do_action( 'woocommerce_after_variations_form' ); ?>
	</form>

	<?php } else {

	echo sprintf( '<a rel="nofollow" href="%s" data-quantity="%s" data-product_id="%s" data-product_sku="%s" class="%s">%s</a>',
			esc_url( $product->add_to_cart_url() ),
			esc_attr( isset( $quantity ) ? $quantity : 1 ),
			esc_attr( $product->id ),
			esc_attr( $product->get_sku() ),
			esc_attr( isset( $class ) ? $class : 'button' ),
			esc_html( $product->add_to_cart_text() )
		);

	}

}

Если вы начинаете разбираться с WooCommerce, то не забудьте посетить нашу рубрику WooCommerce, где мы публикуем материалы специально по тематике магазинов на этой платформе.

По всем вопросам и отзывам просьба писать в комментарии ниже.

Не забывайте, по возможности, оценивать понравившиеся записи количеством звездочек на ваше усмотрение.

VN:F [1.9.22_1171]
Rating: 5.0/5 (1 vote cast)

Об авторе ADv

Занимаюсь разработкой сайтов и магазинов на WordPress. Оказываю платные помощь и консультации. Skype: advokat_b
  • Nikolay Alexeev

    Добрый день! Возможно не по теме, но не нашел, где спросить. Заранее прошу простить.

    Вопрос такой. В списке вариантов атрибута для вариативных товаров, кроме самих значений, есть пункт «варианты» или «выберите вариант». При его выборе цена не выводится. Что понятно — вариант то не выбран. Можно как-то это запретить. Чтобы какой-то из вариантов всегда был выбран. Тем более, для каждого товара установлено значение по умолчанию.

    Заранее признателен!

Scroll To Top