【HTML】之form表单元素详解

HTML表单是网页与用户交互的关键组成部分,它允许用户输入数据并将数据提交到服务器进行处理。本文将全面详细地介绍HTML表单的各个方面,从基础元素到高级用法,并提供丰富的代码示例和中文注释,帮助你彻底掌握表单的使用。

1. 表单的基本结构

表单由 <form> 元素定义,所有表单元素都必须放在 <form> 标签内。<form> 元素有两个关键属性:

  • action:指定表单数据提交的目标URL。例如 process_form.php 或 submit.aspx。如果没有指定,表单数据将提交到当前页面。

  • method:指定提交数据的方式,常用的有 GET 和 POST 两种:

    • GET: 将表单数据附加在URL后面,以 ? 分隔,例如 form.php?name=john&age=30。GET请求对数据长度有限制,且数据暴露在URL中,安全性较低,适合用于简单的查询。

    • POST: 将表单数据放在HTTP请求体中,不会显示在URL中,安全性更高,适合用于提交敏感数据或大文件上传。

<form action="process_form.php" method="POST">
  <!--  表单元素放在这里 -->
</form>

注释: 上面的代码创建了一个表单,当用户提交表单时,数据将通过 POST 方法发送到 process_form.php 文件进行处理。

2. 常用表单元素

2.1 <label> 标签

<label> 标签用于为表单元素定义标签(标题)。将 <label> 与表单元素关联起来,可以提高用户体验。点击 <label> 会自动将焦点移动到关联的表单元素上。关联方法有两种:

  1. 使用 for 属性:<label> 的 for 属性值应该与关联表单元素的 id 属性值相同。

  2. 将表单元素嵌套在 <label> 标签内:

<label for="username">用户名:</label> <input type="text" id="username" name="username">

<label>密码: <input type="password" name="password"></label>

2.2 输入框 <input>

<input> 元素是最常用的表单元素,它根据 type 属性的不同,呈现各种类型的输入控件。name 属性是必须的,用于标识表单数据字段的名称,服务器端可以通过 name 属性获取对应的值。

  • text: 单行文本输入框。

  • password: 密码输入框,输入的字符会被遮蔽。

  • email: 用于输入邮箱地址,浏览器会进行简单的邮箱格式验证。

  • number: 用于输入数字,可以设置 min、max 和 step 属性来限制输入范围和步长。

  • date: 用于选择日期。

  • time: 用于选择时间。

  • datetime-local: 用于选择日期和时间。

  • month: 用于选择月份和年份。

  • week: 用于选择周数和年份。

  • range: 用于选择一个范围内的值,通常以滑块的形式展现。需要配合 min、max 和 step 属性使用。

  • color: 用于选择颜色。

  • search: 用于输入搜索关键词,外观通常是一个带有搜索图标的文本框。

  • tel: 用于输入电话号码。

  • url: 用于输入网址,浏览器会进行简单的网址格式验证。

  • radio: 单选按钮,同一组单选按钮的 name 属性必须相同,这样用户只能选择其中一个选项。value 属性指定选中该选项时提交的值。

  • checkbox: 复选框,可以多选。value 属性指定选中该选项时提交的值。

  • file: 用于上传文件。

  • hidden: 隐藏字段,用于存储一些不需要用户输入的数据,例如用户ID。

  • submit: 提交按钮,用于提交表单数据。value 属性设置按钮上的文本。

  • image: 图像按钮,可以作为提交按钮使用。需要指定 src 属性来设置图像路径。

  • reset: 重置按钮,用于重置表单数据到初始值。value 属性设置按钮上的文本。

  • button: 普通按钮,需要通过 JavaScript 来定义其功能。

<label for="username">用户名:</label> <input type="text" id="username" name="username" placeholder="请输入用户名">
<label for="password">密码:</label> <input type="password" id="password" name="password">
<input type="submit" value="提交">

2.3 下拉列表 <select> 和 <option>

<select> 元素用于创建下拉列表,<option> 元素定义列表中的选项。multiple 属性可以让 <select> 支持多选。

<label for="city">城市:</label>
<select id="city" name="city">
  <option value="beijing">北京</option>
  <option value="shanghai" selected>上海</option> <!--- selected 属性设置默认选中项 -->
  <option value="guangzhou">广州</option>
</select>

2.4 文本域 <textarea>

<textarea> 元素用于多行文本输入。rows 和 cols 属性分别设置行数和列数。

<label for="message">留言:</label> <textarea id="message" name="message" rows="5" cols="30"></textarea>

2.5 <button> 元素

<button> 元素可以创建更灵活的按钮,它比 <input type="submit"> 更强大,因为可以在 <button> 标签内添加内容,例如图像和文本格式。

<button type="submit">提交</button>

2.6 <fieldset> 和 <legend>

<fieldset> 元素用于将相关的表单元素分组,<legend> 元素为 <fieldset> 定义标题。

<fieldset>
  <legend>个人信息</legend>
  <label for="name">姓名:</label> <input type="text" id="name" name="name"><br>
  <label for="email">邮箱:</label> <input type="email" id="email" name="email">
</fieldset>

3. 表单属性

除了 action 和 method 属性外,<form> 元素还有其他一些常用的属性:

  • enctype:指定表单数据的编码方式,常用的有 application/x-www-form-urlencoded (默认值) 和 multipart/form-data (用于文件上传)。

  • target:指定提交表单后在哪里显示结果,例如 _blank 在新窗口中打开。

  • novalidate:禁用客户端表单验证。

  • accept、autocomplete、autofocus、disabled、form、list、maxlength、minlength、multiple、name、pattern、placeholder、readonly、required、size、step、value 等,具体含义请参考上一版本内容。

4. 表单验证

HTML5 提供了丰富的表单验证功能,例如:

  • required 属性:指定字段为必填字段。

  • pattern 属性:使用正则表达式验证输入格式。

  • min 和 max 属性:设置数字输入的范围。

  • minlength 和 maxlength 属性:设置文本输入的长度限制。
    此外,还可以使用 JavaScript 进行更复杂的表单验证。

5.案例

代码:

<!DOCTYPE html>
<html lang="en">

<head>
     <meta charset="UTF-8">
     <meta http-equiv="X-UA-Compatible" content="IE=edge">
     <meta name="viewport" content="width=device-width, initial-scale=1.0">
     <title>HTML-表单</title>
</head>

<body>
     <div align="center"">
          <!-- value: 表单项提交的值 -->
     <form action="" method=" post">
          姓名: <input type="text" name="name"> <br><br>
          密码: <input type="password" name="password"> <br><br>
          性别: <input type="radio" name="gender" value="1"> 男
          <label><input type="radio" name="gender" value="2"> 女 </label> <br><br>
          爱好: <label><input type="checkbox" name="hobby" value="java"> java </label>
          <label><input type="checkbox" name="hobby" value="game"> game </label>
          <label><input type="checkbox" name="hobby" value="sing"> sing </label> <br><br>
          图像: <input type="file" name="image"> <br><br>
          生日: <input type="date" name="birthday"> <br><br>
          时间: <input type="time" name="time"> <br><br>
          日期时间: <input type="datetime-local" name="datetime"> <br><br>
          邮箱: <input type="email" name="email"> <br><br>
          年龄: <input type="number" name="age"> <br><br>
          学历: <select name="degree">
               <option value="">----------- 请选择 -----------</option>
               <option value="1">大专</option>
               <option value="2">本科</option>
               <option value="3">硕士</option>
               <option value="4">博士</option>
          </select> <br><br>
          描述: <textarea name="description" cols="30" rows="10"></textarea> <br><br>
          <input type="hidden" name="id" value="1">

          <!-- 表单常见按钮 -->
          <input type="button" value="按钮">
          <input type="reset" value="重置">
          <input type="submit" value="提交">
          <br>
          </form>
     </div>

</body>

</html>

运行:

6. 总结

本文详细介绍了 HTML 表单的各个方面,包括基本结构、常用元素、表单属性和表单验证。通过学习本文,你应该能够熟练地创建和使用 HTML 表单,并实现各种用户交互功能。

学习网站推荐:面向开发者的 Web 技术 | MDN

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/904217.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

shodan5,参数使用,批量查找Mongodb未授权登录,jenkins批量挖掘

查找美国安全局漏洞 nww.nsa.gov&#xff08;美国安全局官方网站) net参数使用 搜索指定的ip网段 shodan search --limit 10 --fields ip_str,port net:208.88.84.0/24 (老美国家安全局的一个网段)可能直接访问不太行&#xff0c;可以使用host参数&#xff0c;得到域名再去…

【Unity基础】初识UI Toolkit - 编辑器UI

&#xff08;本文所需图片在文章上面的资源中&#xff0c;点击“立即下载”。&#xff09; 本文介绍了如何通过UI工具包&#xff08;UI Toolkit&#xff09;来创建一个编辑器UI。 一、创建项目 1. 打开Unity创建一个空项目&#xff08;任意模板&#xff09;&#xff0c;这里我…

NVR小程序接入平台/设备EasyNVR多个NVR同时管理多平台级联与上下级对接的高效应用

政务数据共享平台的建设正致力于消除“信息孤岛”现象&#xff0c;打破“数据烟囱”&#xff0c;实现国家、省、市及区县数据的全面对接与共享。省市平台的“级联对接”工作由多级平台共同构成&#xff0c;旨在满足跨部门、跨层级及跨省数据共享的需求&#xff0c;推动数据流通…

Android 获取OAID

获取OAID 老规矩&#xff0c;直接上&#xff1a; implementation com.huawei.hms:opendevice:6.11.0.300 // 要获取华为vaid 和aaid&#xff0c;还需添加opendevice 依赖implementation(name: oaid_sdk_2.5.0, ext: aar) import android.content.Context; import android.util.…

Flume采集Kafka数据到Hive

版本&#xff1a; Kafka&#xff1a;2.4.1 Flume&#xff1a;1.9.0 Hive&#xff1a;3.1.0 Kafka主题准备&#xff1a; Hive表准备&#xff1a;确保hive表为&#xff1a;分区分桶、orc存储、开启事务 Flume准备&#xff1a; 配置flume文件&#xff1a; /opt/datasophon/flume-1…

还在担心你收藏的书签下架或失效?试试这款自托管书签管理器『Linkwarden』吧!

还在担心你收藏的书签下架或失效&#xff1f;试试这款自托管书签管理器『Linkwarden』吧&#xff01; 哈喽&#xff0c;小伙伴儿们好&#xff0c;我是Stark-C~ 随着大家在网上收藏的浏览器书签越来越多&#xff0c;难免会导致管理混乱的问题。可能会在我们需要的时候难以找到…

MySQL与金蝶云星空数据集成,实现生产用料清单自动刷新

MySQL数据集成到金蝶云星空&#xff1a;zz-生产用料清单主动刷新 在企业的日常运营中&#xff0c;数据的及时性和准确性至关重要。为了实现MySQL数据库与金蝶云星空系统之间的数据无缝对接&#xff0c;我们设计并实施了一个名为“zz-生产用料清单主动刷新”的集成方案。本案例…

八,Linux基础环境搭建(CentOS7)- 安装Mysql和Hive

Linux基础环境搭建&#xff08;CentOS7&#xff09;- 安装Mysql和Hive 大家注意以下的环境搭建版本号&#xff0c;如果版本不匹配有可能出现问题&#xff01; 一、Mysql下载及安装 MySQL是一个关系型数据库管理系统&#xff0c;由瑞典MySQL AB 公司开发&#xff0c;属于 Orac…

计算机毕业设计Python+大模型恶意木马流量检测与分类 恶意流量监测 随机森林模型 深度学习 机器学习 数据可视化 大数据毕业设计 信息安全 网络安全

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; Python大模型恶意木马流量检…

Conditional DETR论文笔记

原文链接 [2108.06152] Conditional DETR for Fast Training Convergencehttps://arxiv.org/abs/2108.06152 原文笔记 What 《Conditional DETR for Fast Training Convergence》 这个工作也是针对于DETR Query的工作 用于解决DETR训练收敛慢&#xff08;Object query需要…

LoRA微调,真的有毒!

本文介绍一篇相当有意思的文章&#xff0c;该文章的内容对我们使用指令微调将预训练模型改造为 Chat 模型和下游专业模型相当有指导意义。 本文的标题听起来有些唬人&#xff0c;有些标题党&#xff0c;但是这个论点在一定的限定条件下是成立的&#xff0c;笔者归纳为&#xf…

Qt——信号和槽

一.信号和槽概述 谈及信号&#xff0c;很容易联想到在Linux系统中所分享到的信号。那么Linux信号和Qt信息有什么不同&#xff1f; 在 Qt 中&#xff0c;用户和控件的每次交互过程称为⼀个事件。比如 "用户点击按钮" 是⼀个事件&#xff0c;"用户关 闭窗口&quo…

Nginx反向代理(下)

1. WebSocket的反向代理 WebSocket 是目前比较成熟的技术了, WebSocket 协议为创建客户端和服务器端需要实时双向通讯的 webapp 提供了一个选择。服务器可以向浏览器推送相关消息&#xff0c;这样在前端实现的某个页面中我们可以及时看到服务器的状态变化而不用使用定时刷新去…

2024年10月中国数据库排行榜:TiDB续探花,GaussDB升四强

10月中国数据库流行度排行榜如期发布&#xff0c;再次印证了市场分层的加速形成。国家数据库测评结果已然揭晓&#xff0c;本批次通过的产品数量有限&#xff0c;凸显了行业标准的严格与技术门槛的提升。再看排行榜&#xff0c;得分差距明显增大&#xff0c;第三名与后续竞争者…

【C++】RBTree——红黑树

文章目录 一、红黑树的概念1.1 红⿊树的规则&#xff1a;1.2 理解最长路径长度不超过最短路径长度的 2 倍1.3 红⿊树的效率 二、 红⿊树的实现2.1 红⿊树的结构2.2 红⿊树的插⼊2.2.1 红⿊树树插⼊⼀个值的⼤概过程 2.3 红⿊树的插⼊代码实现 一、红黑树的概念 红⿊树是⼀棵⼆…

git下载和配置

git是什么&#xff1f; Git是一种分布式版本控制系统&#xff0c;用于跟踪文件的变化&#xff0c;尤其是源代码。它允许多个开发者在同一项目上进行协作&#xff0c;同时保持代码的历史记录。Git的主要特点包括&#xff1a; 分布式&#xff1a;每个开发者都有项目的完整副本&a…

[MySQL#6] 表的CRUD (1) | Create | Retrieve(查) | where

目录 1. 插入 1.1 单行数据 - 全列插入 指定列插入 1.2 多行数据 - 全列插入 指定列插入 1.3 更新 1.4 替换 2. 查找 2.1 select 列 2.2 where 条件 具体案例 2.3 结果排序 总结关键字执行顺序 2.4 筛选分页结果 CRUD : Create(创建)&#xff0c;Retrieve(读取)&…

C语言:代码运行的底层奥秘,编译和链接

目录 翻译环境和运行环境编译环境预编译&#xff08;预处理&#xff09;编译词法分析语法分析语义分析 汇编 链接运行环境 翻译环境和运行环境 在ANSI C的任何⼀种实现中&#xff0c;存在两个不同的环境。 第1种是翻译环境&#xff0c;在这个环境中源代码被转换为可执行的机器…

2024 FinTechathon 校园行:助力高校学生探索金融科技创新

在金融科技蓬勃发展的当下&#xff0c;人才培养成为推动行业前行的关键。为推进深圳市金融科技人才高地建设&#xff0c;向高校学子提供一个展示自身知识、能力和创意的平台&#xff0c;2024 FinTechathon 深圳国际金融科技大赛——西丽湖金融科技大学生挑战赛重磅开启&#xf…

第7章 内容共享

第 7 章 内容共享 bilibili学习地址 github代码地址 本章介绍Android不同应用之间共享内容的具体方式&#xff0c;主要包括&#xff1a;如何利用内容组件在应用之间共享数据&#xff0c;如何使用内容组件获取系统的通讯信息&#xff0c;如何借助文件提供器在应用之间共享文件…