我正在尝试使用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');
此代码段用于将多选下拉列表保存到数据库中。
答案 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;