加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 保存选择字段的(多个)元值

发布时间:2020-12-13 22:23:03 所属栏目:PHP教程 来源:网络整理
导读:我无法保存选择字段框中包含的元数据.只是一个例子(将function.php挂钩到单个产品设置页面): (...) select style="width:100%" id="_receita" name="_receita[]" multiple="multiple" data-placeholder="?php _e( 'Search for a product','woocommerce' );
我无法保存选择字段框中包含的元数据.只是一个例子(将function.php挂钩到单个产品设置页面):

(...)


    <select style="width:100%" id="_receita" name="_receita[]" multiple="multiple" data-placeholder="<?php _e( 'Search for a product','woocommerce' ); ?>">
            <?php
                echo '<option value="TEST"> TEST </option>';
                echo '<option value="TEST1"> TEST1 </option>';
                echo '<option value="TEST2"> TEST2 </option>';
                ?>
            </select>

    // few others custom fields:
   <?php $ingrediente_x_quantidade = get_post_meta( $post->ID,'_ingrediente_x_quantidade',true ); ?>  
            <input placeholder="<?php _e( 'Ingrediente','woocommerce' ); ?>" type="text" class="ingrediente" id ="_ingrediente" name="_ingrediente" value="<?php echo $ingrediente_x_quantidade[0]; ?>" style="width: 90%;" />
            <input placeholder="<?php _e( 'qnt.','woocommerce' ); ?>" type="number" name="_quantidade" id="_quantidade" class = "quantidade" value="<?php echo $ingrediente_x_quantidade[1]; ?>" step="any" min="0" style="width: 25%;" />

(...)

为了保存数据,我在function.php中包括:

add_action( 'woocommerce_product_options_general_product_data','woo_add_custom_general_fields' );
    // Save Fields
    add_action( 'woocommerce_process_product_meta','woo_add_custom_general_fields_save' );


function woo_add_custom_general_fields_save( $post_id ){

// Custom Field
 $ingrediente_x_quantidade =  array( esc_attr( $_POST['_ingrediente'] ),esc_attr( $_POST['_quantidade'] ) );
 update_post_meta( $post_id,$ingrediente_x_quantidade );

 // Select Field
 foreach ($_POST["_receita"] as $receita) {
 update_post_meta($post->ID,"_receita",$receita);
        }

        }

我正在为自定义字段(“_ingrediente_x_quantidade”)获得一切正常,但对于选择字段,“_ renita”我得到一个空数组:

[_ingrediente_x_quantidade] => Array
(
[0] => a:2:{i:0;s:19:”Aveia,flocos,crua”;i:1;s:3:”113″;}
)

[_receita] => Array
(
[0] =>
)

我做错了什么?我很擅长编码!

解决方法

我发现使用foreach存储数据存在一个问题,每个记录都有相同的密钥和帖子ID …

尝试在base使用它:

update_post_meta($post->ID,serialize($receita));

$receita = unserialize(get_post_meta($post->ID,true));

使用对空数组的检查也是好的…

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读