Каков наилучший способ правильно переопределить ранее существовавшую функцию WooCommerce? В этом случае я хочу изменить wc_price()
. Мне не нужно делать что-то безумное с этим, мне просто нужно добавить атрибут HTML <span>
по цене.
Я знаю, что код выглядит следующим образом:
function wc_price( $price, $args = array() ) { extract( apply_filters( 'wc_price_args', wp_parse_args( $args, array( 'ex_tax_label' => false, 'currency' => '', 'decimal_separator' => wc_get_price_decimal_separator(), 'thousand_separator' => wc_get_price_thousand_separator(), 'decimals' => wc_get_price_decimals(), 'price_format' => get_woocommerce_price_format(), ) ) ) ); $negative = $price < 0; $price = apply_filters( 'raw_woocommerce_price', floatval( $negative ? $price * -1 : $price ) ); $price = apply_filters( 'formatted_woocommerce_price', number_format( $price, $decimals, $decimal_separator, $thousand_separator ), $price, $decimals, $decimal_separator, $thousand_separator ); if ( apply_filters( 'woocommerce_price_trim_zeros', false ) && $decimals > 0 ) { $price = wc_trim_zeros( $price ); } $formatted_price = ( $negative ? '-' : '' ) . sprintf( $price_format, '<span class="woocommerce-Price-currencySymbol">' . get_woocommerce_currency_symbol( $currency ) . '</span>', $price ); $return = '<span class="woocommerce-Price-amount amount">' . $formatted_price . '</span>'; if ( $ex_tax_label && wc_tax_enabled() ) { $return .= ' <small class="woocommerce-Price-taxLabel tax_label">' . WC()->countries->ex_tax_or_vat() . '</small>'; } return apply_filters( 'wc_price', $return, $price, $args ); }
Все, что я хочу сделать, это изменить его на:
function wc_price( $price, $args = array() ) { extract( apply_filters( 'wc_price_args', wp_parse_args( $args, array( 'ex_tax_label' => false, 'currency' => '', 'decimal_separator' => wc_get_price_decimal_separator(), 'thousand_separator' => wc_get_price_thousand_separator(), 'decimals' => wc_get_price_decimals(), 'price_format' => get_woocommerce_price_format(), ) ) ) ); $negative = $price < 0; $price = apply_filters( 'raw_woocommerce_price', floatval( $negative ? $price * -1 : $price ) ); $price = apply_filters( 'formatted_woocommerce_price', number_format( $price, $decimals, $decimal_separator, $thousand_separator ), $price, $decimals, $decimal_separator, $thousand_separator ); if ( apply_filters( 'woocommerce_price_trim_zeros', false ) && $decimals > 0 ) { $price = wc_trim_zeros( $price ); } $formatted_price = ( $negative ? '-' : '' ) . sprintf( $price_format, '<span class="woocommerce-Price-currencySymbol">' . get_woocommerce_currency_symbol( $currency ) . '</span>', <span class="custom-prc"> . $price . </span> ); $return = '<span class="woocommerce-Price-amount amount">' . $formatted_price . '</span>'; if ( $ex_tax_label && wc_tax_enabled() ) { $return .= ' <small class="woocommerce-Price-taxLabel tax_label">' . WC()->countries->ex_tax_or_vat() . '</small>'; } return apply_filters( 'wc_price', $return, $price, $args ); }
Любая помощь вообще будет очень признательна! Благодаря!
Чтобы добавить свой собственный html-тег <span class="custom-prc">0000</span>
по цене, вам нужно будет использовать функцию hooked в formatted_woocommerce_price
фильтрах следующим образом:
add_filter( 'formatted_woocommerce_price', 'span_custom_prc', 10, 5 ); function span_custom_prc( $number_format, $price, $decimals, $decimal_separator, $thousand_separator){ return '<span class="custom-prc">'.$number_format.'</span>'; }
Код идет в файле function.php вашей активной дочерней темы (или темы), а также в любом файле плагина.
Код протестирован и работает с WooCommerce 3+
Затем вы получите этот выход html (например, с 42,00 euros
):
<span class="price"> <span class="woocommerce-Price-amount amount"> <span class="custom-prc">42,03</span> " " <span class="woocommerce-Price-currencySymbol">€</span> </span> </span>