ホームページ > バックエンド開発 > PHPチュートリアル > 単一属性商品の WooCommerce バリエーション ドロップダウンで在庫状況を表示するにはどうすればよいですか?

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

DDD
リリース: 2024-10-30 14:54:03
オリジナル
920 人が閲覧しました

How to Display Stock Status in WooCommerce Variation Dropdown for Single-Attribute Products?

WooCommerce バリエーション ドロップダウンでバリエーション在庫ステータスを強化する方法

問題:

WooCommerce 製品で商品バリエーションを表示するときページのドロップダウンでは、各バリエーションの在庫状況 (在庫あり/在庫切れなど) をすぐに確認できません。

解決策:

単一属性の関数を更新しましたバリエーション (2021 年に導入)

注: このソリューションは、ドロップダウン属性が 1 つだけある可変商品に適しています。

wc_dropdown_variation_attribute_options 関数を変更します:

<code class="php">add_filter( 'woocommerce_dropdown_variation_attribute_options_html', 'show_stock_status_in_dropdown', 10, 2);
function show_stock_status_in_dropdown( $html, $args ) {
    // Ensure there's only one variation attribute
    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 );
        $show_option_none = $args['show_option_none'] ? true : false;

        if ( ! empty( $options ) ) {
            $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>';

            foreach ( $options as $option ) {
                $stock_status = get_stock_status_text( $product, $name, $option );
                $html .= '<option value="' . esc_attr( $option ) . '" ' . selected( sanitize_title( $args['selected'] ), $option, false ) . '>' . esc_html( apply_filters( 'woocommerce_variation_option_name', $option ) . $stock_status ) . '</option>';
            }
            $html .= '</select>';
        }
    }
    return $html;
}</code>
ログイン後にコピー

追加機能: 各バリエーションの在庫状況テキストを取得します

<code class="php">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)';
}</code>
ログイン後にコピー

使用法:

上記のコード スニペットをテーマの function.php ファイルまたはプラグイン ファイル。

制限事項:

  • 提供されるソリューションは、1 つのドロップダウン属性を持つ可変商品にのみ適用されます。
  • 複数のドロップダウンを持つ商品の場合属性により、在庫状況の表示が正確でない場合があります。

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

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート