每次保存复选框值时附加重复值

时间:2014-06-10 16:08:25

标签: php wordpress drop-down-menu

我正在尝试使用Wordpress模板页面上的“jQuery UI MultiSelect Widget”(http://www.erichynds.com/blog/jquery-ui-multiselect-widget)创建一个多选下拉列表,并将选中的选项保存到数据库(Mysql)中作为单个字符串值。

问题:每次单击“保存表单”时,都会附加重复值(即A,B,A,B)。如果我在此下拉列表中选择新选项,则不会发生此问题。顺便说一下,文本框,单选下拉列表或textarea等其他字段都可以。

下面是我认为问题来自的两个代码段,所以有人请帮我指出这里出了什么问题。整个星期我一直在解决这个问题,但没有运气!非常感谢你!

    <?php
case 'maker_dropdown':
    global $wpdb;
    $makers = $wpdb->get_var( $wpdb->prepare( "SELECT field_values FROM ". $wpdb->prefix . "cp_ad_fields WHERE field_name = 'cp_maker';", "" ) );
    $selected_makers = $wpdb->get_var( $wpdb->prepare( "SELECT meta_value FROM ". $wpdb->prefix . "usermeta WHERE meta_key = 'maker' AND user_id =" . $user->ID . ";", "" ) );

    if ($makers) {
?>
   <select name="<?php echo $field_id; ?>[]" class="regular-dropdown multiselect"  multiple="multiple" >
<?php                           
   $options = explode( ',', $makers);  
   $selected_options = explode( ',', $selected_makers);  

   foreach ( $options as $option) { // loop thru all available options
       if ( in_array($option, $selected_options)) { 
?>
           <option name="<?php echo $option; ?>[]" selected="selected" value="<?php esc_attr_e($the_value); ?>"><?php esc_attr_e($option); ?></option>
<?php
       }
       else {
?>
           <option  value="<?php esc_attr_e($option); ?>"><?php esc_attr_e($option); ?></option>
<?php
       }
    } //endforeach
?>
    </select>
<?php } //endif ?>
break;

此代码段用于在前端显示多选下拉列表。

function ctm_profile_fields_save($user_id) {
global $ctm_extra_profile_fields;

foreach ($ctm_extra_profile_fields as $field_id => $field_values) :
    $selected_options = implode(',', $_POST[$field_id]);

    if ($field_values['type'] == 'maker_dropdown') {
        update_user_meta( $user_id, $field_id, $selected_options );
    }
    else { 
        update_user_meta( $user_id, $field_id, sanitize_text_field(  $_POST[$field_id] ) ); 
    }
endforeach;
}
add_action('personal_options_update', 'ctm_profile_fields_save');
add_action('edit_user_profile_update', 'ctm_profile_fields_save');

此代码段用于将多选下拉列表保存到数据库中。

1 个答案:

答案 0 :(得分:0)

update_user_meta函数允许使用相同密钥的多个元条目。

当您为用户阅读现有制作人时,您可能会得到[&#39; A&#39;,&#39; B&#39;]。保存提交的表单后,您可以添加一组新的选定值[&#39; A&#39;,&#39; B&#39;]。这就是你的价值观重复的原因。

有两种简单的方法可以解决这个问题。

选项1:在保存之前清除元键。

foreach ($ctm_extra_profile_fields as $field_id => $field_values) :
    $selected_options = implode(',', $_POST[$field_id]);

    delete_user_meta($user_id, $field_id);

    if ($field_values['type'] == 'maker_dropdown') {
        update_user_meta( $user_id, $field_id, $selected_options );
    }
    else { 
        update_user_meta( $user_id, $field_id, sanitize_text_field(  $_POST[$field_id] ) ); 
    }
endforeach;

选项2:在update_user_meta中指定先前的值以不创建重复的条目

foreach ($ctm_extra_profile_fields as $field_id => $field_values) :
    $selected_options = implode(',', $_POST[$field_id]);

    if ($field_values['type'] == 'maker_dropdown') {
        update_user_meta( $user_id, $field_id, $selected_options, $selected_options );
    }
    else { 
        update_user_meta( $user_id, $field_id, sanitize_text_field(  $_POST[$field_id] ), sanitize_text_field(  $_POST[$field_id] ) ); 
    }
endforeach;