这是解决此问题的一种方法。但是如果你使用一些表单输入,比如文本表单,我建议你使用 Ajax 回调,因为它会感觉更动态。如果您想要一个如何使用 Ajax 回调解决它的示例,请告诉我?
我想这里的关键是我使用$form_state['rebuild'] = true;
了这样的形式来重建表格,并且很容易从$form_state['values']
这是代码:
function example_form(array $form, array &$form_state)
{
$form['temp'] = array(
'#type' => 'value',
'#value' => array_key_exists('values', $form_state) ? $form_state['values']['temp'] + 1 : 1,
);
if (array_key_exists('values', $form_state) && $form_state['values']['temp'] == 1)
{
$form['message'] = array(
'#markup' => t('I only give you one warning'),
'#prefix' => '<p>',
'#suffix' => '</p>',
);
}
$form['submit_button'] = array(
'#type' => 'submit',
'#value' => t('Click Here!'),
);
return $form;
}
function example_form_validate(array $form, array &$form_state)
{
$form_state['rebuild'] = true;
}
function example_form_submit(array $form, array &$form_state)
{
if($form_state['values']['temp'] == 1) {
// I will not store anything
} else {
// now I will store it :)
}
}