PHP表单验证警报,无需重定向页面

时间:2012-05-15 23:18:25

标签: php javascript popup alert

基本上发生的事情是我有一个PHP表单来发送电子邮件。在整个过程中有几个不同的验证步骤,这些步骤都很有效。我想做的是,如果在提交表单时出现验证错误,则会弹出一个javascript警报。我使用以下php:

// Validate email
if(!filter_var($EmailFrom, FILTER_VALIDATE_EMAIL))
{
  echo "<script language=javascript>alert('Please Use a Valid Email Address')</script>";
  exit;
}

警告会弹出,但页面会重定向到domain.com/sendemail.php,从而为用户留下空白页。我真的希望弹出警报而不重新加载页面。我该怎么做?

3 个答案:

答案 0 :(得分:0)

这是我用于快速验证它们的某些形式的脚本。它非常简单有效,希望对您有所帮助。

<script type="text/javascript">
function validate(){ 
    emailfilter = /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/;
    condition = 1;
    mensaje = "Complete: ";
    //Validate 1st input (Check if empty)
    if (document.formname.forminput1.value.length==0){ 
         condition = 0;
         msg = msg + "-Input 1 is empty "
    }
        //Validate 1nd input (Check email)
    if (!emailfilter.test(document.formname.forminput1.value)) {
         condition = 0;
         msg = msg + "-Input 1 has a invalid email adresss "
    }

    if (condition == 0){ 
         alert(msg) 
         document.formname.forminput1.focus() 
         return 0; 
    }

    //send
    alert("Form sended."); 
    document.formname.submit(); 
} 
</script>

答案 1 :(得分:0)

您可以使用ajax来完成此任务。但是如果您不想使用ajax,而是在出错时退出,则可以将其重定向回到表单页面以及查询字符串参数。

header("Location: http://www.example.com/form.php?error=1");

在您的表单页面上,您可以使用php编写脚本。像

这样的东西
<?php if(isset($_GET['error']) && $_GET['error']==1): ?>
<script>
....
</script>
<?php endif; ?>

这将实现您的目标。实际上,您可以执行多项检查并根据您的检查设置错误。但我仍然建议Ajax将提供更好的用户体验。

答案 2 :(得分:0)

编辑:超级简单的解决方案,使用jQuery表单插件:http://jquery.malsup.com/form/

我在某些网络应用中做了类似的事情,您可能会发现它很有用。

我做验证服务器端,如果遇到错误,我会这样做:

json_die(array(
  'status' => 'error',
  'message'=> 'Your error message'
));

并取得成功:

json_die(array(
  'status' => 'success',
  'message'=> 'Your success message'
));

json_die的功能是:

function json_die($array) {
        header("content-type: application/json");
        die(json_encode($array, true));
}

然后在前端我做这样的事情:

  $.post('/your_url', {
                        'your': vars

                    }, function (r) {

                      if(r.status == 'success') {

                           alert(r.message);

                        } else if (r.status == 'error') {

                            alert(r.message);
                             //handle error

                        } else {
                           alert('server exploded / no connection');
                         }

                    },'json');