如何在 Woocommerce 中保存属性的自定义字段?

Jes*_*lón 2 wordpress woocommerce

老的

我正在尝试在 Woocommerce 的产品属性中创建自定义字段。这样就能够选择是否突出显示某个属性。例如:

https://i.stack.imgur.com/Ge76B.png

我想要做的是,我在后端指定为突出显示的字段以某种方式在前端显示。

到目前为止,我已经能够添加该字段,但我还没有弄清楚如何保存它。这就是我所拥有的:

add_action('woocommerce_after_product_attribute_settings','wcb_add_product_attribute_is_highlighted', 10, 2);
add_filter( 'woocommerce_admin_meta_boxes_prepare_attribute', 'wcb_admin_meta_boxes_prepare_attribute', 10, 3);

function get_attribute_highlighted($id, $i) {
    return get_post_meta( 1, "attribute_".$id."_highlighted_".$i, true);
}

function wcb_add_product_attribute_is_highlighted($attribute, $i=0) {
    $value = get_attribute_highlighted($attribute->get_id(), $i); ?>
    <tr>
        <td>
            <div class="enable_variation show_if_canopytour show_if_variable_canopytour">
                <label><input type="checkbox" class="checkbox" <?php checked( $value, true ); ?> name="attribute_highlighted[<?php echo esc_attr( $i ); ?>]" value="1" /> <?php esc_html_e( 'Highlight attribute', $this->wcb ); ?></label>
            </div>
        </td>
    </tr>
<?php
}

function wcb_admin_meta_boxes_prepare_attribute($attribute, $data, $i=0) {
    // updated
    if(array_key_exists("attribute_highlighted", $data) && is_array($data["attribute_highlighted"])) {
        update_post_meta( 1, "attribute_".$attribute->get_id()."_highlighted_".$i, wc_string_to_bool($data["attribute_highlighted"][$i]) );
    }
}
Run Code Online (Sandbox Code Playgroud)

我尝试woocommerce_admin_meta_boxes_prepare_attribute使用类的offsetSetoffsetGet方法进行过滤WC_Product_Attribute,但我无法理解它是如何工作的。我无法让它保存我的自定义值。

升级

woocommerce_admin_meta_boxes_prepare_attribute通过wp_ajax_woocommerce_save_attributes操作更改了过滤器,它似乎有效。现在我遇到了第一次保存后没有更新的问题。

我解释当前的问题:我有一个复选框,当单击该复选框时,它会被激活,我会保存它,并在重新加载时保持它的状态。如果现在我想停用它,保存状态后,它不会保持为禁用状态,而是会恢复为激活状态。

这是更新后的代码:

add_action('woocommerce_after_product_attribute_settings', 'wcb_add_product_attribute_is_highlighted', 10, 2);
add_action('wp_ajax_woocommerce_save_attributes', 'wcb_ajax_woocommerce_save_attributes', 10);

function get_attribute_highlighted($id, $i) {
    global $post;
    $id = sanitize_title($id);
    $id = strtolower($id);
    $val = get_post_meta( $post->ID, "attribute_".$id."_highlighted_".$i, true);
    return !empty($val) ? $val : false;
}

function wcb_add_product_attribute_is_highlighted($attribute, $i=0) {
    $value = get_attribute_highlighted($attribute->get_name(), $i); ?>
        <tr>
            <td>
                <div class="enable_highlighted show_if_canopytour show_if_variable_canopytour">
                    <label><input type="checkbox" class="checkbox" <?php checked( $value, true ); ?> name="attribute_highlighted[<?php echo esc_attr( $i ); ?>]" value="1" /> <?php esc_html_e( 'Highlight attribute', $this->wcb ); ?></label>
                </div>
            </td>
        </tr>
    <?php
}

function wcb_ajax_woocommerce_save_attributes() {
    check_ajax_referer( 'save-attributes', 'security' );
    parse_str( $_POST['data'], $data );
    $post_id = absint( $_POST['post_id'] );
    if(array_key_exists("attribute_highlighted", $data) && is_array($data["attribute_highlighted"])) {
        foreach($data["attribute_highlighted"] as $i => $val) {
            $attr_name = sanitize_title($data["attribute_names"][$i]);
            $attr_name = strtolower($attr_name);
            update_post_meta( $post_id, "attribute_".$attr_name."_highlighted_".$i, wc_string_to_bool($val) );
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

Jes*_*lón 5

检查Ink 的答案


过时的

我已经找到了解决我的问题的方法。我分享代码以防有人有用。问候!

add_action('woocommerce_after_product_attribute_settings', 'wcb_add_product_attribute_is_highlighted', 10, 2);
add_action('wp_ajax_woocommerce_save_attributes', 'wcb_ajax_woocommerce_save_attributes', 10);

function get_attribute_highlighted($id, $i) {
    global $post;
    $id = sanitize_title($id);
    $id = strtolower($id);
    $val = get_post_meta( $post->ID, "attribute_".$id."_highlighted_".$i, true);
    return !empty($val) ? $val : false;
}

function wcb_add_product_attribute_is_highlighted($attribute, $i=0) {
    $value = get_attribute_highlighted($attribute->get_name(), $i); ?>
        <tr>
            <td>
                <div class="enable_highlighted">
                    <label><input type="hidden" name="attribute_highlighted[<?php echo esc_attr( $i ); ?>]" value="0" /><input type="checkbox" class="checkbox" <?php checked( $value, true ); ?> name="attribute_highlighted[<?php echo esc_attr( $i ); ?>]" value="1" /> <?php esc_html_e( 'Highlight attribute', $this->wcb ); ?></label>
                </div>
            </td>
        </tr>
    <?php
}

function wcb_ajax_woocommerce_save_attributes() {
    check_ajax_referer( 'save-attributes', 'security' );
    parse_str( $_POST['data'], $data );
    $post_id = absint( $_POST['post_id'] );
    if(array_key_exists("attribute_highlighted", $data) && is_array($data["attribute_highlighted"])) {
        foreach($data["attribute_highlighted"] as $i => $val) {
            $attr_name = sanitize_title($data["attribute_names"][$i]);
            $attr_name = strtolower($attr_name);
            update_post_meta( $post_id, "attribute_".$attr_name."_highlighted_".$i, wc_string_to_bool($val) );
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

最后,我唯一需要添加到代码中的是一个隐藏输入,其名称与复选框相同,但值为 0:<input type="hidden" name="attribute_highlighted[<?php echo esc_attr( $i ); ?>]" value="0" />

这是结果的图像(https://i.stack.imgur.com/VscT1.jpg)。通过单击“保存”,复选框的值将被保留。该值保存在您正在修改的帖子的 post_meta 中。如果您想在前端突出显示特定属性,这非常有用。

我感谢@LoicTheAztec 的帮助:)