表单与交互:HTML表单标签全面解析

news2025/2/10 16:25:15

目录

前言

一.HTML表单的基本结构

基本结构

示例

二.常用表单控件

文本输入框

选择控件

文件上传

按钮

综合案例 

三.标签的作用

四.注意事项


前言

HTML(超文本标记语言)是构建网页的基础,其中表单(<form>)元素用于收集用户输入的数据。在表单中,<label>标签与表单控件密切配合,提升用户体验和可访问性。本文将详细讲解HTML表单的基本结构、常用控件、<label>标签的作用及相关注意事项。


一.HTML表单的基本结构

表单通过<form>标签定义,包含用户可交互的控件,如文本框、按钮、复选框等。表单的主要作用是收集用户输入,并将数据发送到服务器进行处理。

基本结构

<form action="提交目标URL" method="提交方法">
  <!-- 表单控件 -->
</form>
  • action:指定表单数据提交的目标URL,即服务器端处理程序的地址。
  • method:定义数据提交方式,常用的有:
    • GET:将表单数据附加在URL之后,适用于获取数据,数据量有限制。
    • POST:在HTTP请求体中发送表单数据,适用于提交敏感信息或大量数据。

示例

<form action="/submit" method="post">
  <!-- 表单控件 -->
</form>
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    
    <title>表单基本结构</title>
</head>
<body>
    <form action="https://www.baidu.com/s" target="_blank" method="get">
        <input type="text" name="wd"></input>
        <button>去百度搜索</button>
    </form>
    <form action="https://search.jd.com/Search" target="_self" method="get">
        <input type="text" name="keyword"></input>
        <button>去京东搜索</button>
    </form>
    <hr>
    <a href="https://www.baidu.com/s?wd=你好">百度搜索你好</a>
</body>
</html>

 


二.常用表单控件

HTML提供了多种表单控件,满足不同的用户输入需求。以下是一些常用的控件及其描述:

  1. 文本输入框

    • 单行文本框:

      <input type="text" name="username" placeholder="请输入用户名">
      
      • type="text":定义单行文本输入。
      • name:控件名称,用于表单数据提交时标识。
      • placeholder:提供占位提示文本。
    • 密码框:

      <input type="password" name="password" placeholder="请输入密码">
      
      • type="password":输入内容以掩码形式显示,适用于密码输入。
    • 多行文本框:

      <textarea name="message" rows="4" cols="50" placeholder="请输入留言"></textarea>
      
      • <textarea>:用于多行文本输入。
      • rowscols:定义文本区域的行数和列数。
  2. 选择控件

    • 复选框:

      <input type="checkbox" name="subscribe" value="newsletter"> 订阅新闻
      
      • type="checkbox":允许用户进行多选。
      • value:提交时的值。
    • 单选按钮:

      <input type="radio" name="gender" value="male"> 男
      <input type="radio" name="gender" value="female"> 女
      
      • type="radio":在一组选项中仅允许选择一个。
      • name:相同的name属性将这些按钮分组。
    • 下拉列表:

      <select name="country">
        <option value="china">中国</option>
        <option value="usa">美国</option>
        <option value="uk">英国</option>
      </select>
      
      • <select>:创建下拉列表。
      • <option>:定义列表中的选项。
  3. 文件上传

    <input type="file" name="profile_picture">
    
    • type="file":允许用户选择文件上传。
  4. 按钮

    • 提交按钮:

      <input type="submit" value="提交">
      
      • type="submit":点击后提交表单。
    • 重置按钮:

      <input type="reset" value="重置">
      
      • type="reset":点击后重置表单内容。
    • 普通按钮:

      <button type="button" onclick="alert('按钮被点击')">点击我</button>
      
      • <button>:可包含文本或HTML元素的按钮。
      • type="button":定义为普通按钮,不会提交表单。

综合案例 

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>表单控件</title>
</head>
<body>
    <form action="https://search.jd.com/Search">
        账户:<input type="text" name="account" value="hulin" maxlength="10" placeholder="请输入用户名"><br><!--value默认值-->
        密码:<input type="password" name="password" placeholder="请输入密码"></input><br>
        性别:
        <!--单选-->
        <input type="radio" name="gender" value="男" checked>男<!--chexk默认选中-->
        <input type="radio" name="gender" value="女">女
       <br>
       <!--多选-->
        爱好:
        <input type="checkbox" name="hobby" value="打篮球" checked>打篮球</input>
        <input type="checkbox" name="hobby" value="打游戏">打游戏</input>
        <input type="checkbox" name="hobby" value="看电影">看电影</input>
        <br>
        其他:
        <textarea name="other" cols="30" rows="10"></textarea>
        <br>
        <!--下拉框-->
        籍贯:
        <select name="address">
            <option value="北京">北京</option>
            <option value="上海" selected>上海</option><!--默认选择-->
            <option value="广东">广东</option>
            <option value="深圳">深圳</option>
        </select>
        <!---->
        <!--隐藏域-->
        <br>
        <input type="hidden" name="type" value="1"></input>
        <!--确认按钮-->
        <!--<button>确认</button>  默认按钮类型是submit-->
        <br>
        <button type="submit" values="确认">确认</button>
        <button type="reset">重置</button>
        <!--重置按钮-->
        <!--<input type="reset" value="重置"></input> -->
        <!--普通按钮-->
        <input type="button" value="普通按钮"></input>
    </form>
</body>
</html>

 


三.<label>标签的作用

<label> 标签用于为表单控件定义标签,提升用户体验和可访问性。通过点击 <label>,用户可以聚焦到对应的表单控件。

有两种方式将 <label> 与表单控件关联:

  1. 使用 for 属性<label>for 属性值应与对应表单控件的 id 属性值相同。

    <label for="email">电子邮件:</label>
    <input type="email" id="email" name="email">
    

  2. 将表单控件嵌套在 <label> 内部:此时无需使用 forid 属性。

    <label>电子邮件:<input type="email" name="email"></label>
    

需要注意的是,避免在 <label> 内嵌套可交互的元素,如链接或按钮,以免影响用户体验。

综合案例,fieldset和legend将单独写一篇进行补充。

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>表单控件</title>
</head>
<body>
    <form action="https://search.jd.com/Search">
        <fieldset>
            <legend>基本信息</legend>
            <label for="zhanghu">账户:</label>  <!--for与id关联,点击label标签,会自动聚焦到id对应的input标签上-->
        <input id="zhanghu" type="text" name="account" value="hulin" maxlength="10"><br>
        <label>
            密码:
            <input type="password" name="password" ></input>
        </label>
        </fieldset>
        <br>
        <fieldset>
            <legend>附加信息</legend>
            性别:
        <!--单选-->
          <label>
            <input type="radio" name="gender" value="男" >男</input>
          </label>
           
       
            <input type="radio" name="gender" value="女"  id="nv"></input>
            <label for="nv">女</label>
      
       <br>
       <!--多选-->
        爱好:
        <label><input type="checkbox" name="hobby" value="打篮球" checked>打篮球</input></label>
        <label><input type="checkbox" name="hobby" value="打游戏">打游戏</input></label>
        <label><input type="checkbox" name="hobby" value="看电影">看电影</input></label>
        
        </fieldset>
        
        <br>
        其他:
        <textarea name="other" cols="30" rows="10"></textarea>
        <br>
        <!--下拉框-->
        籍贯:
        <select name="address">
            <option value="北京">北京</option>
            <option value="上海" selected>上海</option><!--默认选择-->
            <option value="广东">广东</option>
            <option value="深圳">深圳</option>
        </select>
        <!---->
        <!--隐藏域-->
        <br>
        <input type="hidden" name="type" value="1"></input>
        <!--确认按钮-->
        <!--<button>确认</button>  默认按钮类型是submit-->
        <br>
        <button type="submit">确认</button>
        <button type="reset">重置</button>
        <!--重置按钮-->
        <!--<input type="reset" value="重置"></input> -->
        <!--普通按钮-->
        <input type="button" value="普通按钮"></input>
    </form>
</body>
</html>

四.注意事项

  • 表单验证:确保在客户端和服务器端对用户输入进行验证,保证数据的完整性和安全性。

  • 可访问性:为每个表单控件提供对应的 <label>,以提升对使用辅助技术的用户的友好度。

  • 布局与样式:使用 CSS 对表单进行美化,确保在不同设备上的一致性和响应性。

  • 安全性:防止跨站脚本(XSS)和跨站请求伪造(CSRF)等安全漏洞,确保表单提交的安全性。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python基础-元组tuple的学习

在 Python 中&#xff0c;元组&#xff08;tuple&#xff09;是一种不可变的序列类型&#xff0c;允许存储不同类型的元素。元组非常类似于列表&#xff08;list&#xff09;&#xff0c;但与列表不同的是&#xff0c;元组一旦创建&#xff0c;就不能修改其内容。 1 元组的创建…

Vue与Konva:解锁Canvas绘图的无限可能

前言 在现代Web开发中&#xff0c;动态、交互式的图形界面已成为提升用户体验的关键要素。Vue.js&#xff0c;作为一款轻量级且高效的前端框架&#xff0c;凭借其响应式数据绑定和组件化开发模式&#xff0c;赢得了众多开发者的青睐。而当Vue.js邂逅Konva.js&#xff0c;两者结…

go语言文件和目录

打开和关闭文件 os.Open()函数能够打开一个文件&#xff0c;返回一个*File 和一个 err。操作完成文件对象以后一定要记得关闭文件。 package mainimport ("fmt""os" )func main() {// 只读方式打开当前目录下的 main.go 文件file, err : os.Open(".…

Solidity09 Solidity构造函数和修饰器

文章目录 一、构造函数二、修饰器三、OpenZeppelin的Ownable标准实现四、Remix 演示示例五、代码示例 这一讲&#xff0c;我们将用合约权限控制&#xff08; Ownable&#xff09;的例子介绍 Solidity语言中构造函数&#xff08; constructor&#xff09;和独有的修饰器&…

使用wpa_supplicant和wpa_cli 扫描wifi热点及配网

一&#xff1a;简要说明 交叉编译wpa_supplicant工具后会有wpa_supplicant和wpa_cli两个程序生产&#xff0c;如果知道需要连接的wifi热点及密码的话不需要遍历及查询所有wifi热点的名字及信号强度等信息的话&#xff0c;使用wpa_supplicant即可&#xff0c;否则还需要使用wpa_…

大模型应用与实战:专栏概要与内容目录

文章目录 大模型应用与实战&#x1f4da; 核心内容模块一、大模型推理与部署1.1 推理框架应用实践1.2 框架源码深度解析1.3 高并发部署优化1.4 国产化平台适配 二、Agent框架专题2.1 Langchain系列2.2 Qwen-Agent系列2.3 Dify应用实践2.4 框架对比与迁移 三、微调技术研究3.1 微…

Arbess基础教程-创建流水线

Arbess(谐音阿尔卑斯) 是一款开源免费的 CI/CD 工具&#xff0c;本文将介绍如何使用 Arbess 配置你的第一条流水线&#xff0c;以快速入门上手。 1. 创建流水线 根据不同需求来创建不同的流水线。 1.1 配置基本信息 配置流水线的基本信息&#xff0c;如分组&#xff0c;环境&…

科普书《从一到无穷大》的科普知识推翻百年集论

科普书《从一到无穷大》的科普知识推翻百年集论 黄小宁 “我们给两组无穷大数列中的各个数一一配对&#xff0c;如果最后这两组都一个不剩&#xff0c;这两组无穷大就是相等的&#xff1b;如果有一组还有些数没有配出去&#xff0c;这一组就比另一组大些&#xff0c;或者说强些…

【键盘识别】实例分割

第一步 键盘检测 方案一 canny边缘检测 canny边缘检测检测结果不稳定,容易因为复杂背景或光线变换检测出其他目标。 如图是用canny边缘检测方法标出的检测出的边缘的四个红点。 参考的是这篇文章OpenCV实战之三 | 基于OpenCV实现图像校正_opencv 图像校正-CSDN博客 方案二…

25/2/7 <机器人基础>雅可比矩阵计算 雅可比伪逆

雅可比矩阵计算 雅可比矩阵的定义 假设我们有一个简单的两个关节的平面机器人臂&#xff0c;其末端执行器的位置可以表示为&#xff1a; 其中&#xff1a; L1​ 和 L2 是机器人臂的长度。θ1​ 和 θ2是关节的角度。 计算雅可比矩阵 雅可比矩阵 JJ 的定义是将关节速度与末…

apisix的real-ip插件使用说明

k8s集群入口一般都需要过负载均衡&#xff0c;然后再到apisix。 这时候如果后台业务需要获取客户端ip&#xff0c;可能拿到的是lb或者网关的内网ip。 这里一般要获取真实ip需要做几个处理。 1. 负载均衡上&#xff0c;一般支持配置获取真实ip参数&#xff0c;需要配置上。然…

Python实现GO鹅优化算法优化支持向量机SVM分类模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后关注获取。 1.项目背景 随着信息技术的迅猛发展&#xff0c;数据量呈爆炸式增长&#xff0c;如何从海量的数据中提取有价值…

我用AI做数据分析之数据清洗

我用AI做数据分析之数据清洗 AI与数据分析的融合效果怎样&#xff1f; 这里描述自己在使用AI进行数据分析&#xff08;数据清洗&#xff09;过程中的几个小故事&#xff1a; 1. 变量名的翻译 有一个项目是某医生自己收集的数据&#xff0c;变量名使用的是中文&#xff0c;分…

备战蓝桥杯:双指针(滑动窗口)算法之逛花展

P1638 逛画展 - 洛谷 | 计算机科学教育新生态 这道题我们只要用一个kind和一个mp[N]的数组就能解决了 我们的解法1就是暴力枚举&#xff0c;先固定2&#xff0c;从2开始找连续的满足所有种类的最短的子数组&#xff0c;然后固定5&#xff0c;3&#xff0c;1&#xff0c;3&…

collabora online+nextcloud+mariadb在线文档协助

1、环境 龙蜥os 8.9 docker 2、安装docker dnf -y install dnf-plugins-core dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sed -i shttps://download.docker.comhttps://mirrors.tuna.tsinghua.edu.cn/docker-ce /etc/yum.repos.…

深度学习中的Checkpoint是什么?

诸神缄默不语-个人CSDN博文目录 文章目录 引言1. 什么是Checkpoint&#xff1f;2. 为什么需要Checkpoint&#xff1f;3. 如何使用Checkpoint&#xff1f;3.1 TensorFlow 中的 Checkpoint3.2 PyTorch 中的 Checkpoint3.3 transformers中的Checkpoint 4. 在 NLP 任务中的应用5. 总…

用深度学习模型构建海洋动物图像分类保姆教程

使用深度学习模型构建深度学习海洋动物图像分类模型的完整步骤如下&#xff0c;分为关键阶段和详细操作说明&#xff1a; 1. 数据准备与预处理 1.1 数据集组织 按类别分文件夹存储图像&#xff0c;例如&#xff1a;dataset/train/class1/class2/...val/class1/class2/...test…

npm无法加载文件 因为此系统禁止运行脚本

安装nodejs后遇到问题&#xff1a; 在项目里【node -v】可以打印出来&#xff0c;【npm -v】打印不出来&#xff0c;显示npm无法加载文件 因为此系统禁止运行脚本。 但是在winr&#xff0c;cmd里【node -v】,【npm -v】都也可打印出来。 解决方法&#xff1a; cmd里可以打印出…

知识库升级新思路:用生成式AI打造智能知识助手

在当今信息爆炸的时代&#xff0c;企业和组织面临着海量数据的处理和管理挑战。知识库管理系统&#xff08;Knowledge Base Management System, KBMS&#xff09;作为一种有效的信息管理工具&#xff0c;帮助企业存储、组织和检索知识。然而&#xff0c;传统的知识库系统往往依…

蚂蚁爬行最短问题

初二数学问题记录 分析过程 考点&#xff1a;2点之间直线最短。 思考过程&#xff1a;将EBCF以BC为边翻折&#xff0c;EF边翻折后为&#xff0c;则A为蚂蚁需要爬行的最小距离。