2012-12-26 113 views
1

Ik要验证后防止字段重置。我搜索了一些主题,但我不能在我的代码中实现它。验证时保留表单值

if($form_view == true) { 
echo ''; 
if($error != '') { 
    echo '<strong><font color="#FF0000">Fout:</font></strong><br />'.$error.'<br />'; 
} 

echo '<form method="POST" action="'.$filename.'" style="border:0px; margin:0px; padding:0px;"> 
Voornaam 
<br /> 
<input type="text" name="voornaam" maxlength="50" id="input_contact" style="width: 200px; value="'.(isset($_POST['voornaam']) ? $_POST['voornaam'] : '').'"> 
<br /> 
Achteraam 
<br /> 
<input type="text" name="achternaam" maxlength="50" id="input_contact" style="width: 200px; value="'.(isset($_POST['achternaam']) ? $_POST['achternaam'] : '').'"> 
<br /> 
Adres 
<br /> 
<input type="text" name="adres" maxlength="50" id="input_contact" style="width: 400px; value="'.(isset($_POST['adres']) ? $_POST['adres'] : '').'"> 
<br /> 
Postcode <h7><i><small>(1234 AB)</small></i></h7> 
<br /> 
<input type="text" name="postcode" maxlength="7" id="input_contact" style="width: 100px; value="'.(isset($_POST['postcode']) ? $_POST['postcode'] : '').'"> 
<br /> 
Woonplaats 
<br /> 
<input type="text" name="woonplaats" maxlength="50" id="input_contact" style="width: 200px; value="'.(isset($_POST['woonplaats']) ? $_POST['woonplaats'] : '').'"> 
<br /> 
Telefoonnummer <h7><i><small>(0123-456789)</small></i></h7> 
<br /> 
<input type="text" name="telefoonnummer" maxlength="11" id="input_contact" style="width: 100px; value="'.(isset($_POST['telefoonnummer']) ? $_POST['telefoonnummer'] : '').'"> 
<br /><br /> 

如果你能给我一个关于如何在一个领域实现这个例子。

非常感谢

+0

是否最后'echo'ed字符串结束某处? – Havelock

+0

“现场重置”是什么意思?而且,你是否使用javascript进行了验证(也许是使用jQuery验证),还是使用php进行验证?或两者? –

回答

1

如果该信息不是他们降落在那么$ _ POST变量将不包含此信息的特定页面进行。

它的快速和肮脏的是将$ _SESSION []中提交的信息保存为一个数组。

当表单被提交时,除了做任何你现在正在做的事情之外,你还需要在接收脚本中保存提交到会话中的信息。

if ($_POST['submit']) { 
// repeat or configure as desired to save submitted fields into Session 
$_SESSION['form_info']['email_address'] = $_POST['email_address']; 
} 

在表单页面本身,你会使用以下

if (isset($_SESSION['form_info'])) { 
// You'll want to most likely consider filtering these using appropriate functions. 
<input type="text" name="email_address" maxlength="50" id="email_address" style="width: 200px; value="<?php if (isset($_SESSION['form_info']['email_address']) { $_SESSION['form_info']['email_address']; } ?>"> 

} 
0

的形式操作变量$文件名指的是这个特殊的PHP文件或在确认发生别的地方?如果表单动作发生在别的地方,Moylin的答案就是你的解决方案(使用$ _SESSION)。否则,如果可能的话,在这里进行验证是合理和简单的。正如你所做的那样,将$ _POST回显到值字段应该足够了(如果你想要短代码,你甚至不需要那里的三元操作)。

<form method="POST" action="thisPhpFile.php" > 

value ="'. @$_POST['voornaam'] .'" 

在验证部分(呼应形式)之前,你自然要检查所有的错误,必填字段等。如果一切是有效的只是点到用户想要的位置。沿着这些线的东西:

if(isset($_POST['mySubmit'] { 
    //check errors/validate 
    if($valid == true) { 
    Header("Location: yourLocation.php"); 
    } 
} 
else { 
    //echo your form here 
} 
+0

谢谢大家。我仍然不明白如何实现这一点。 @ art2是的,我得到了一切在一个PHP文件。我用http://forum.fnl.nl/showthread.php?t=1836的代码也许会有所帮助。非常感谢! – user1930171

相关问题