WooCommerce 製品バリエーションのドロップダウンで在庫状況を表示するにはどうすればよいですか?

Barbara Streisand
リリース: 2024-10-31 14:37:02
オリジナル
865 人が閲覧しました

How to Display Stock Status in WooCommerce Product Variation Dropdown?

WooCommerce 製品バリエーション ドロップダウンで在庫状況を表示する方法

質問:

どうすればよいですかWooCommerce 製品ページのドロップダウン リストに各製品バリエーションの在庫状況 (在庫あり/在庫切れ) を表示しますか?

答え:

2021 年更新 (制限事項):

次のコードは、1 つのドロップダウン (1 つの属性) を持つ可変商品でのみ機能します。複数の属性とドロップダウンを持つ商品の場合、在庫状況が正しく表示されない可能性があります。

1 つのドロップダウン バリエーションの修正コード:

<code class="php">// Function that checks stock status and adds text to the dropdown option
function get_stock_status_text($product, $name, $term_slug) {
    foreach ($product->get_available_variations() as $variation) {
        if ($variation['attributes'][$name] == $term_slug) {
            $stock = $variation['is_in_stock'];
            break;
        }
    }
    return $stock == 1 ? ' - (In Stock)' : ' - (Out of Stock)';
}

// Function that filters the dropdown options and adds stock status
add_filter('woocommerce_dropdown_variation_attribute_options_html', 'show_stock_status_in_dropdown', 10, 2);
function show_stock_status_in_dropdown($html, $args) {
    // Only for products with one variation attribute (one dropdown)
    if (sizeof($args['product']->get_variation_attributes()) == 1) {
        $options = $args['options'];
        $product = $args['product'];
        $attribute = $args['attribute'];
        $name = $args['name'] ? $args['name'] : 'attribute_' . sanitize_title($attribute);
        $id = $args['id'] ? $args['id'] : sanitize_title($attribute);
        $class = $args['class'];
        $show_option_none = $args['show_option_none'] ? true : false;
        $show_option_none_text = $args['show_option_none'] ? $args['show_option_none'] : __('Choose an option', 'woocommerce');

        if (empty($options) && !empty($product) && !empty($attribute)) {
            $attributes = $product->get_variation_attributes();
            $options = $attributes[$attribute];
        }

        $html = '<select id="' . esc_attr($id) . '" class="' . esc_attr($class) . '" name="' . esc_attr($name) . '" data-attribute_name="attribute_' . esc_attr(sanitize_title($attribute)) . '" data-show_option_none="' . ($show_option_none ? 'yes' : 'no') . '">';
        $html .= '<option value="">' . esc_html($show_option_none_text) . '</option>';

        if (!empty($options)) {
            if ($product && taxonomy_exists($attribute)) {
                $terms = wc_get_product_terms($product->get_id(), $attribute, array('fields' => 'all'));

                foreach ($terms as $term) {
                    if (in_array($term->slug, $options)) {
                        $stock_status = get_stock_status_text($product, $name, $term->slug);
                        $html .= '<option value="' . esc_attr($term->slug) . '" ' . selected(sanitize_title($args['selected']), $term->slug, false) . '>' . esc_html(apply_filters('woocommerce_variation_option_name', $term->name) . $stock_status) . '</option>';
                    }
                }
            } else {
                foreach ($options as $option) {
                    $selected = sanitize_title($args['selected']) === $args['selected'] ? selected($args['selected'], sanitize_title($option), false) : selected($args['selected'], $option, false);
                    $stock_status = get_stock_status_text($product, $name, $option);
                    $html .= '<option value="' . esc_attr($option) . '"' . $selected . '>' . esc_html(apply_filters('woocommerce_variation_option_name', $option) . $stock_status) . '</option>';
                }
            }
        }
        $html .= '</select>';
    }

    return $html;
}</code>
ログイン後にコピー

注:

  • このコードをfunctions.php ファイルまたはカスタム プラグインに追加します。
  • 「attribute」をバリエーション属性の実際の名前に置き換えます。

制限事項:

  • このコードは、1 つのドロップダウン バリエーション (1 つの属性) を持つ商品にのみ機能します。
  • 複数の属性とドロップダウンを持つ商品の場合、在庫状況が正しく表示されない場合がございます。

以上がWooCommerce 製品バリエーションのドロップダウンで在庫状況を表示するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!