最新的Web开发教程
 

PHP 5个表格 - 必须填写


本章介绍了如何使所需的输入字段,如果需要创建错误消息。


PHP - 必填字段

从前面的页面上的验证规则表中,我们看到, "Name""E-mail""Gender"字段是必需的。 这些字段不能为空,并在HTML表格必须填写。

领域 验证规则
名称 需要。 +只能包含字母和空格
电子邮件 需要。 +必须包含一个有效的电子邮件地址(with @ and .)
网站 可选的。 如果存在,它必须包含一个有效的URL
评论 可选的。 多行输入字段(textarea)
性别 需要。 必须选择一个

在前面的章节中,所有输入字段都是可选的。

在下面的代码,我们增加了一些新的变量:$ nameErr,$ emailErr,$ genderErr,和$ websiteErr。 这些错误的变量将保持所需的字段错误消息。 我们还增加了一个if else语句每个$ _ POST变量。 这用来检查$ _POST变量是空的(with the PHP empty()函数)。 如果为空,则错误消息被存储在不同的误差变量,如果它不是空的,它通过将用户输入数据test_input()函数:

<?php
// define variables and set to empty values
$nameErr = $emailErr = $genderErr = $websiteErr = "";
$name = $email = $gender = $comment = $website = "";

if ($_SERVER["REQUEST_METHOD"] == "POST") {
  if (empty($_POST["name"])) {
    $nameErr = "Name is required";
  } else {
    $name = test_input($_POST["name"]);
  }

  if (empty($_POST["email"])) {
    $emailErr = "Email is required";
  } else {
    $email = test_input($_POST["email"]);
  }

  if (empty($_POST["website"])) {
    $website = "";
  } else {
    $website = test_input($_POST["website"]);
  }

  if (empty($_POST["comment"])) {
    $comment = "";
  } else {
    $comment = test_input($_POST["comment"]);
  }

  if (empty($_POST["gender"])) {
    $genderErr = "Gender is required";
  } else {
    $gender = test_input($_POST["gender"]);
  }
}
?>

PHP - 显示错误消息

然后,在HTML表格,我们每个必需字段,其产生如果需要的话(即如果用户试图提交表单不填写所需的字段)正确的错误消息后加少许脚本:

<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">

Name: <input type="text" name="name">
<span class="error">* <?php echo $nameErr;?></span>
<br><br>
E-mail:
<input type="text" name="email">
<span class="error">* <?php echo $emailErr;?></span>
<br><br>
Website:
<input type="text" name="website">
<span class="error"><?php echo $websiteErr;?></span>
<br><br>
Comment: <textarea name="comment" rows="5" cols="40"></textarea>
<br><br>
Gender:
<input type="radio" name="gender" value="female">Female
<input type="radio" name="gender" value="male">Male
<span class="error">* <?php echo $genderErr;?></span>
<br><br>
<input type="submit" name="submit" value="Submit">

</form>
运行示例»

下一步是验证输入的数据,那就是"Does the Name field contain only letters and whitespace?""Does the E-mail field contain a valid e-mail address syntax?" ,如果填写了, "Does the Website field contain a valid URL?"