如何将分组产品表格/表格放入Woocommerce的下拉菜单中?我的一些产品有超过10个“儿童产品”。因此列表可能非常广泛。也许有一个数量框并添加到购物车只有下拉不同的选项?目前我不知道是否有可能选择子产品手有产品图像更改。
以下是woo commerce的Grouped.php文件:
<?php
/**
* Grouped product add to cart
*
* @author WooThemes
* @package WooCommerce/Templates
* @version 2.1.7
*/
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly
}
global $product, $post;
$parent_product_post = $post;
do_action( 'woocommerce_before_add_to_cart_form' ); ?>
<form class="cart" method="post" enctype='multipart/form-data'>
<table cellspacing="0" class="group_table">
<tbody>
<?php
foreach ( $grouped_products as $product_id ) :
$product = wc_get_product( $product_id );
$post = $product->post;
setup_postdata( $post );
?>
<tr>
<td>
<?php if ( $product->is_sold_individually() || ! $product->is_purchasable() ) : ?>
<?php woocommerce_template_loop_add_to_cart(); ?>
<?php else : ?>
<?php
$quantites_required = true;
woocommerce_quantity_input( array( 'input_name' => 'quantity[' . $product_id . ']', 'input_value' => '0' ) );
?>
<?php endif; ?>
</td>
<td class="label">
<label for="product-<?php echo $product_id; ?>">
<?php echo $product->is_visible() ? '<a href="' . get_permalink() . '">' . get_the_title() . '</a>' : get_the_title(); ?>
</label>
</td>
<?php do_action ( 'woocommerce_grouped_product_list_before_price', $product ); ?>
<td class="price">
<?php
echo $product->get_price_html();
if ( $availability = $product->get_availability() ) {
$availability_html = empty( $availability['availability'] ) ? '' : '<p class="stock ' . esc_attr( $availability['class'] ) . '">' . esc_html( $availability['availability'] ) . '</p>';
echo apply_filters( 'woocommerce_stock_html', $availability_html, $availability['availability'], $product );
}
?>
</td>
</tr>
<?php
endforeach;
// Reset to parent grouped product
$post = $parent_product_post;
$product = wc_get_product( $parent_product_post->ID );
setup_postdata( $parent_product_post );
?>
</tbody>
</table>
<input type="hidden" name="add-to-cart" value="<?php echo esc_attr( $product->id ); ?>" />
<?php if ( $quantites_required ) : ?>
<?php do_action( 'woocommerce_before_add_to_cart_button' ); ?>
<button type="submit" class="single_add_to_cart_button button alt"><?php echo $product->single_add_to_cart_text(); ?></button>
<?php do_action( 'woocommerce_after_add_to_cart_button' ); ?>
<?php endif; ?>
答案 0 :(得分:0)
我在寻找同一问题的答案时遇到了这个问题。我有多种订阅产品,用户将需要一种升级它们的方法。当显示woocommerce
分组产品页面时,这很糟糕。我从页面的内部循环中删除了该开关。将其替换为quantity
的{{1}}值的if语句。然后,我变得很有创意,解决了将物品实际添加到购物车所需的正确表单元素的问题。我使用jQuery放置了另一个$column_id
输入,然后使用在下拉列表中选择的正确hidden
产品填充了隐藏的输入。 Bam全部解决,应用自定义样式并填充所需的任何产品。
name
这里是jQuery,以备您查看其工作原理.....
<?php
/**
* Grouped product add to cart
*
* This template can be overridden by copying it to yourtheme/woocommerce/single-product/add-to-cart/grouped.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 WooCommerce/Templates
* @version 3.4.0
*/
defined( 'ABSPATH' ) || exit;
global $product, $post;
do_action( 'woocommerce_before_add_to_cart_form' ); ?>
<form class="cart grouped_form" action="<?php echo esc_url( apply_filters( 'woocommerce_add_to_cart_form_action', $product->get_permalink() ) ); ?>" method="post" enctype='multipart/form-data'>
<?php
$quantites_required = false;
$previous_post = $post;
$grouped_product_columns = apply_filters( 'woocommerce_grouped_product_columns', array(
'quantity',
'label',
'price',
), $product );
$options = '';
foreach ( $grouped_products as $grouped_product_child ) {
$post_object = get_post( $grouped_product_child->get_id() );
$quantites_required = $quantites_required || ( $grouped_product_child->is_purchasable() && ! $grouped_product_child->has_options() );
$post = $post_object; // WPCS: override ok.
setup_postdata( $post );
//echo '<div id="product-' . esc_attr( $grouped_product_child->get_id() ) . '" class="card woocommerce-grouped-product-list-item ' . esc_attr( implode( ' ', wc_get_product_class( '', $grouped_product_child->get_id() ) ) ) . '">';
// Output columns for each product.
foreach ( $grouped_product_columns as $column_id ) {
do_action( 'woocommerce_grouped_product_list_before_' . $column_id, $grouped_product_child );
if ($column_id === 'quantity'){
do_action( 'woocommerce_before_add_to_cart_quantity' );
$options .= '<option value="quantity[' . $grouped_product_child->get_id() . ']">' . $grouped_product_child->get_name() .$grouped_product_child->get_price_html(). '</option>';
do_action( 'woocommerce_after_add_to_cart_quantity' );
}
// switch ( $column_id ) {
// case 'label':
// $value = '<div class="card-title" for="product-' . esc_attr( $grouped_product_child->get_id() ) . '">';
// $value .= $grouped_product_child->is_visible() ? '<span>' . $grouped_product_child->get_name() . '</span>' : $grouped_product_child->get_name();
// $value .= '</div>';
// break;
// case 'price':
// $value = $grouped_product_child->get_price_html() . wc_get_stock_html( $grouped_product_child );
// break;
// case 'quantity':
// ob_start();
// if ( ! $grouped_product_child->is_purchasable() || $grouped_product_child->has_options() || ! $grouped_product_child->is_in_stock() ) {
// woocommerce_template_loop_add_to_cart();
// } elseif ( $grouped_product_child->is_sold_individually() ) {
// echo '<input type="checkbox" name="' . esc_attr( 'quantity[' . $grouped_product_child->get_id() . ']' ) . '" value="1" class="wc-grouped-product-add-to-cart-checkbox" />';
// } else {
// do_action( 'woocommerce_before_add_to_cart_quantity' );
// woocommerce_quantity_input( array(
// 'input_name' => 'quantity[' . $grouped_product_child->get_id() . ']',
// 'input_value' => isset( $_POST['quantity'][ $grouped_product_child->get_id() ] ) ? wc_stock_amount( wc_clean( wp_unslash( $_POST['quantity'][ $grouped_product_child->get_id() ] ) ) ) : 0,
// 'min_value' => apply_filters( 'woocommerce_quantity_input_min', 0, $grouped_product_child ),
// 'max_value' => apply_filters( 'woocommerce_quantity_input_max', $grouped_product_child->get_max_purchase_quantity(), $grouped_product_child ),
// ) );
// do_action( 'woocommerce_after_add_to_cart_quantity' );
// }
// $value = ob_get_clean();
// break;
// default:
// $value = '';
// break;
// }
//echo '<div class="card-body woocommerce-grouped-product-list-item__' . esc_attr( $column_id ) . '">' . apply_filters( 'woocommerce_grouped_product_list_column_' . $column_id, $value, $grouped_product_child ) . '</div>'; // WPCS: XSS ok.
do_action( 'woocommerce_grouped_product_list_after_' . $column_id, $grouped_product_child );
}
// echo '</div>';
}
?>
<div class="row">
<div class="col-6 mb-3">
<?php
echo '<select class="multi-prod form-control">'.$options.'</select>';
echo '<input type="hidden" class="input-text qty text" name="" value="">';
$post = $previous_post; // WPCS: override ok.
setup_postdata( $post );
?>
</div>
</div>
<input type="hidden" name="add-to-cart" value="<?php echo esc_attr( $product->get_id() ); ?>" />
<?php if ( $quantites_required ) : ?>
<?php do_action( 'woocommerce_before_add_to_cart_button' ); ?>
<button type="submit" class="single_add_to_cart_button btn btn-success">Upgrade</button>
<?php do_action( 'woocommerce_after_add_to_cart_button' ); ?>
<?php endif; ?>
</form>
<?php do_action( 'woocommerce_after_add_to_cart_form' ); ?>
答案 1 :(得分:0)
已经装好了,看起来好像正在工作。谢谢!
$('.multi-prod').change(function(e){
var $this = $(this);
$('.qty').attr('name', $this.val());
});