Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/wordpress/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 每次保存复选框值时附加的重复值_Php_Wordpress_Drop Down Menu - Fatal编程技术网

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

Php 每次保存复选框值时附加的重复值,php,wordpress,drop-down-menu,Php,Wordpress,Drop Down Menu,我试图在Wordpress模板页面上使用“jQuery UI multiselect Widget”()创建一个多选下拉列表,并将选中的选项作为单个字符串值保存到数据库(Mysql)中 问题是:每次单击“保存表单”时都会追加重复的值(即A、B、A、B)。如果在此下拉列表中选择新选项,则不会出现此问题。顺便说一句,其他字段如文本框、单选下拉列表或文本区域都可以 下面是我认为问题来自的两个代码段,所以请有人帮我指出这里出了什么问题。我已经解决这个问题整整一周了,但是运气不好!多谢各位 <

我试图在Wordpress模板页面上使用“jQuery UI multiselect Widget”()创建一个多选下拉列表,并将选中的选项作为单个字符串值保存到数据库(Mysql)中

问题是:每次单击“保存表单”时都会追加重复的值(即A、B、A、B)。如果在此下拉列表中选择新选项,则不会出现此问题。顺便说一句,其他字段如文本框、单选下拉列表或文本区域都可以

下面是我认为问题来自的两个代码段,所以请有人帮我指出这里出了什么问题。我已经解决这个问题整整一周了,但是运气不好!多谢各位

    <?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;

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

update\u user\u meta函数允许使用同一密钥创建多个元条目

当您阅读用户的现有制造商时,您可能会得到['A','B']。当您保存提交的表单时,您会将一组新的选定值['a','B']添加到以前的值中。这就是您的值被复制的原因

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

选项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:在更新\用户\元中指定上一个值,以不创建重复条目

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;

感谢MattStypa提供的解决方案,我尝试了两个选项,但很抱歉,这两个选项都无法解决我的问题:(
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;