0

在我正在开发的 Wordpress 插件中,我使用的是 WordPress 设置 API。在我用来显示包含单选按钮的设置的回调中,我启用它们并根据复选框值禁用它们。无论如何,即使它们被禁用,我也尝试使用隐藏输入来存储它们的值,但这使情况变得更糟,因为它总是采用最后一个隐藏输入的值,在我的情况下是“4”。

if(get_option( 'display_style' ) == 2){
$disabled = 'disabled';
}
$html = '<input type="radio" id="onecolumn" class="cardchecked" name="card_columns" value="1"' . checked( 1, get_option( 'card_columns' ), false ) . $disabled . '/>';  
$html .= '<input type="hidden" name="card_columns" value="1" />';  
$html .= '<label for="onecolumn">One</label>';  

$html .= '<input type="radio" id="twoclumn" class="cardchecked" name="card_columns" value="2"' . checked( 2, get_option( 'card_columns' ), false ) . $disabled . '/>';  
$html .= '<input type="hidden" name="card_columns" value="2" />';  
$html .= '<label for="twoclumn">Two</label>';  

$html .= '<input type="radio" id="threecolumn" class="cardchecked" name="card_columns" value="3"' . checked( 3, get_option( 'card_columns' ), false ) . $disabled . '/>';  
$html .= '<input type="hidden" name="card_columns" value="3" />';  
$html .= '<label for="threecolumn">Three</label>';  

$html .= '<input type="radio" id="fourcolumn" class="cardchecked" name="card_columns" value="4"' . checked( 4, get_option( 'card_columns' ), false ) . $disabled . '/>';  
$html .= '<input type="hidden" name="card_columns" value="4" />';  
$html .= '<label for="fourcolumn">Four</label>';  
echo $html;
4

1 回答 1

1

隐藏的输入name不能与无线电输入的相同,name因为它的值是恒定的,并且将覆盖任何具有相同的先前输入的值name

if(get_option( 'display_style' ) == 2){
$disabled = 'disabled';
}
$html .= '<input type="hidden" name="card_columns" value="1" />'; 
$html = '<input type="radio" id="onecolumn" class="cardchecked" name="card_columns" value="1"' . checked( 1, get_option( 'card_columns' ), false ) . $disabled . '/>';    
$html .= '<label for="onecolumn">One</label>';  
...

您必须使用 javascript 设置隐藏输入字段的值。在您的单选顶部仅放置一个隐藏输入将确保如果单选按钮被禁用,则隐藏输入的值被提交,但如果您的单选按钮被启用,它们将覆盖隐藏输入的值。

于 2013-09-17T01:36:22.313 回答