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