【问题标题】:Handle WooCommerce selected variation custom field conditional display处理 WooCommerce 选择的变体自定义字段条件显示
【发布时间】:2021-06-21 02:55:01
【问题描述】:

我有这段代码,我需要根据以下条件插入一个值:**///////// HERE THE MY CODE /////////**

在这里,我通过我的活动主题覆盖了 single-product/add-to-cart/variation.php Woocommerce 模板文件:

<script type="text/template" id="tmpl-variation-template">
<div class="woocommerce-variation-description">
{{{ data.variation.variation_description }}}
</div>
 
<div class="woocommerce-variation-price">
{{{ data.variation.price_html }}}
</div>
 
<div class="woocommerce-variation-custom_field">
{{{ data.variation.custom_field}}}
///////// HERE MY CODE /////////
</div>
 
<div class="woocommerce-variation-availability">
{{{ data.variation.availability_html }}}
</div>
</script>

The condition should check the value of the variable `{{{ data.variation.custom_field}}}` and if this data is greater than 10 then the code should print "Yes". 

**Something like**: 

    if( $data.variation.custom_field > 10 ){ 
        echo "yes";
    }

But it's not working. I guess, this should be done using Javascript instead of php but I don't know how grab the variable value.

【问题讨论】:

  • 你在这里使用什么模板系统?它没有被标记。
  • data.variation.custom_field 可能是在此处使用的任何模板语言中访问此类嵌套变量的正确表示法 - 但它肯定不是在普通 PHP 中访问它的正确方法。点. 是该级别的连接运算符。
  • 我从未见过原生 WooCommerce 模板文件使用这种模板语法。很确定这里肯定有一些额外的组件在起作用。
  • 好的,那么它应该是这个文件,github.com/woocommerce/woocommerce/blob/release/5.0/templates/… ?这意味着这些是客户端上的下划线库使用的模板,codex.wordpress.org/Javascript_Reference/wp.template 不确定数据是否对 PHP 可用,直接在该模板文件中。 (您可以尝试执行var_dump($data);,以查看该名称的变量是否存在于该上下文中。)
  • 那么在 in underscorejs 中执行此操作可能更有意义。 stackoverflow.com/questions/7230470/…

标签: javascript php wordpress templates woocommerce


【解决方案1】:

不需要为此使用额外的 javascript(或 jQuery)代码。

如果自定义字段值大于 10,以下将处理显示“YES”的产品变体自定义字段(否则没有)

您需要使用以下方法之一替换使用 woocommerce_available_variation 钩子的现有钩子函数。

主要有2种方式:

1)。最简单的方法,不覆盖variation.php模板:

// Frontend: Handle Conditional display and include custom field value on product variation
add_filter( 'woocommerce_available_variation', 'variation_data_custom_field_conditional_display', 10, 3 );
function variation_data_custom_field_conditional_display( $data, $product, $variation ) {
    // Get custom field value and set it in the variation data array (not for display)
    $data['custom_field'] = $variation->get_meta('custom_field');
    
    // Defined custom field conditional display
    $displayed_value = $data['custom_field'] > 10 ? 'YES' : '';

    // Frontend variation: Display value below formatted price
    $data['price_html'] .= '</div>' . $displayed_value . '
    <div class="woocommerce-variation-custom_field_html">';

    return $data;
}

代码位于活动子主题(或活动主题)的functions.php 文件中。经过测试并且可以工作。

2)。另一种简单的方法 (覆盖variation.php模板)

// Frontend: Handle Conditional display and include custom field value on product variation
add_filter( 'woocommerce_available_variation', 'variation_data_custom_field_conditional_display', 10, 3 );
function variation_data_custom_field_conditional_display( $data, $product, $variation ) {
    // Get custom field value and set it in the variation data array (not for display)
    $data['custom_field'] = $variation->get_meta('custom_field');

    // Frontend display: Define custom field conditional display
    $data['custom_field_html'] = $data['custom_field'] > 10 ? "YES" : "";

    return $data;
}

代码进入活动子主题(或活动主题)的functions.php文件中。

然后在您的自定义模板single-product/add-to-cart/variation.php 中,您将替换:

{{{ data.variation.custom_field}}}

与:

{{{ data.variation.custom_field_html }}}

无需任何额外要求即可正常工作。


这是社区的完整代码示例,基于 2nd Way:

1)。管理员变体: 显示自定义字段并保存其值

// Admin: Add a custom field in product variations options pricing
add_action( 'woocommerce_variation_options_pricing', 'add_admin_variation_custom_field', 10, 3 );
function add_admin_variation_custom_field( $loop, $variation_data, $variation ){

   woocommerce_wp_text_input( array(
        'id'          => 'custom_field['.$loop.']',
        'label'       => __('Custom Field', 'woocommerce' ),
        'placeholder' => __('Enter Custom Field value here', 'woocommerce' ),
        'desc_tip'    => true,
        'description' => __('This field is for … (explanation / description).', 'woocommerce' ),
        'value'       => get_post_meta( $variation->ID, 'custom_field', true )
    ) );
}

// Admin: Save custom field value from product variations options pricing
add_action( 'woocommerce_save_product_variation', 'save_admin_variation_custom_field', 10, 2 );
function save_admin_variation_custom_field( $variation_id, $i ){
    if( isset($_POST['custom_field'][$i]) ){
        update_post_meta( $variation_id, 'custom_field', sanitize_text_field($_POST['custom_field'][$i]) );
    }
}

代码进入活动子主题(或活动主题)的functions.php文件中。

2)。前端变体: 基于所选变体和自定义字段值的条件显示

// Frontend: Handle Conditional display and include custom field value on product variation
add_filter( 'woocommerce_available_variation', 'variation_data_custom_field_conditional_display', 10, 3 );
function variation_data_custom_field_conditional_display( $data, $product, $variation ) {
    // Get custom field value and set it in the variation data array (not for display)
    $data['custom_field'] = $variation->get_meta('custom_field');
    
    // Frontend display: Define custom field conditional display
    $data['custom_field_html'] = $data['custom_field'] > 10 ? __("YES", "woocommerce") : "";
    
    return $data;
}

代码进入活动子主题(或活动主题)的functions.php文件中。

3)。模板覆盖: single-product/add-to-cart/variation.php 文件到您的活动主题的:

<?php
/**
 * Single variation display
 *
 * This is a javascript-based template for single variations (see https://codex.wordpress.org/Javascript_Reference/wp.template).
 * The values will be dynamically replaced after selecting attributes.
 *
 * @see https://docs.woocommerce.com/document/template-structure/
 * @package WooCommerce/Templates
 * @version 2.5.0
 */

defined( 'ABSPATH' ) || exit;

?>
<script type="text/template" id="tmpl-variation-template">
    <div class="woocommerce-variation-description">{{{ data.variation.variation_description }}}</div>
    <div class="woocommerce-variation-price">{{{ data.variation.price_html }}}</div>
    <div class="woocommerce-variation-custom_field">{{{ data.variation.custom_field_html}}}</div>
    <div class="woocommerce-variation-availability">{{{ data.variation.availability_html }}}</div>
</script>
<script type="text/template" id="tmpl-unavailable-variation-template">
    <p><?php esc_html_e( 'Sorry, this product is unavailable. Please choose a different combination.', 'woocommerce' ); ?></p>
</script>

经过测试并且有效。

相关:WooCommerce: Add/display Product or Variation custom field everywhere

【讨论】:

    【解决方案2】:

    基于https://codex.wordpress.org/Javascript_Reference/wp.templatehttps://github.com/blueimp/JavaScript-Templates#evaluation等类似的模板引擎,您需要构建一个带有评估的模板。

    在你的情况下,它应该是这样的:

    <div class="woocommerce-variation-custom_field">
      <#  if (data.variation.custom_field > 10) { #>
        yes
      <# } #>
    </div>
    

    另外,在这里https://lkwdwrd.com/wp-template-js-templates-wp,您可以找到一个带有 if 语句本身的示例。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2021-07-02
      • 2021-04-12
      • 2014-04-20
      • 1970-01-01
      • 2015-04-19
      • 2020-04-04
      • 1970-01-01
      • 2018-04-20
      相关资源
      最近更新 更多