HTML 表单实战:从创建到验证

HTML表单是用于收集用户输入数据的一种方式,可以用于创建各种类型的表单,例如登录表单、注册表单、调查问卷表单等。本文将详细介绍表单元素的使用,并利用JavaScript实现对表单数据的验证。

HTML表单元素的使用

输入框<input>

&lt;input>元素用于接收用户输入的文本。它有许多不同的类型,用于不同的输入需求。

  1. 文本输入框:
html 复制代码
<input type="text" name="username" placeholder="请输入用户名" required>
  1. 密码输入框:
html 复制代码
<input type="password" name="password" placeholder="请输入密码" required>
  1. 单选框:
html 复制代码
<input type="radio" name="gender" value="male" checked>男
<input type="radio" name="gender" value="female">女
  1. 复选框:
html 复制代码
<input type="checkbox" name="hobbies" value="football">足球
<input type="checkbox" name="hobbies" value="basketball">篮球
  1. 文件上传:
html 复制代码
<input type="file" name="avatar" accept="image/png, image/jpeg">
  1. 隐藏输入:
html 复制代码
<input type="hidden" name="id" value="123">

文本域<textarea>

&lt;textarea>元素用于多行文本输入。

html 复制代码
<textarea name="comment" rows="4" cols="50" placeholder="请输入评论内容"></textarea>

下拉菜单<select>

&lt;select>元素用于创建下拉菜单。

html 复制代码
<select name="country">
  <option value="china">中国</option>
  <option value="usa">美国</option>
  <option value="uk">英国</option>
</select>

表单数据的验证

必填项验证

可以通过设置required属性来标记必填项。

html 复制代码
<input type="text" name="username" required>

邮箱格式验证

可以使用正则表达式来验证邮箱格式。

html 复制代码
<input type="email" name="email" pattern="[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,}$">

JavaScript实现表单数据验证

可以使用JavaScript来对表单数据进行验证。以下是一个简单的示例:

html 复制代码
<script>
function validateForm() {
  var username = document.forms["myForm"]["username"].value;
  if (username == "") {
    alert("用户名不能为空");
    return false;
  }
  
  var password = document.forms["myForm"]["password"].value;
  if (password == "") {
    alert("密码不能为空");
    return false;
  }
  
  var email = document.forms["myForm"]["email"].value;
  var emailPattern = /[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,}$/;
  if (!emailPattern.test(email)) {
    alert("邮箱格式不正确");
    return false;
  }
}
</script>

<form name="myForm" onsubmit="return validateForm()">
  <!-- 表单元素 -->
  <input type="text" name="username" required>
  <input type="password" name="password" required>
  <input type="email" name="email" pattern="[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,}$">
  
  <input type="submit" value="提交">
</form>

在上面的示例中,validateForm()函数用于验证表单数据。如果数据不符合要求,会弹出一个警告框并阻止表单提交。

这只是一个简单的示例,实际的表单验证可能需要更复杂的逻辑。你可以根据实际需求来编写验证代码。

希望这些信息对你有所帮助,祝你能够开发出具有基本交互功能的表单页面!

相关推荐
LilyCoder31 分钟前
HTML5二十四节气网站源码
前端·javascript·html·html5
rannn_11113 小时前
【Javaweb学习|黑马笔记|Day1】初识,入门网页,HTML-CSS|常见的标签和样式|标题排版和样式、正文排版和样式
css·后端·学习·html·javaweb
Tony小周2 天前
qml 实现数值键盘
前端·javascript·html
前端老鹰2 天前
HTML <link rel=“preload“>:提前加载关键资源的性能优化利器
前端·性能优化·html
白云~️2 天前
html img标签设置默认图片,防止图片路径不存在导致图片不展示影响页面美观
java·前端·html
xixixin_2 天前
【HTML】在页面中画一条0.5px的线
前端·css·uni-app·html·css3
羊锦磊2 天前
[ HTML 前端 ] 语法介绍和HBuilderX安装
java·开发语言·前端·html
chinahcp20082 天前
CSS保持元素宽高比,固定元素宽高比
前端·css·html·css3·html5
逆风优雅2 天前
vue实现模拟 ai 对话功能
前端·javascript·html
不羁。。2 天前
【web站点安全开发】任务3:网页开发的骨架HTML与美容术CSS
前端·css·html