《HTML 简易速速上手小册》第8章:HTML 表单高级技术(2024 最新版)

news2024/9/25 3:21:47

在这里插入图片描述

文章目录

  • 8.1 数据收集与处理
    • 8.1.1 基础知识
    • 8.1.2 案例 1:创建一个注册表单
    • 8.1.3 案例 2:创建一个调查问卷表单
    • 8.1.4 案例 3:创建一个动态添加输入字段的表单
  • 8.2 定制化表单元素
    • 8.2.1 基础知识
    • 8.2.2 案例 1:创建一个带有定制选择的表单
    • 8.2.3 案例 2:创建一个有动态反馈的评分系统
    • 8.2.4 案例 3:构建一个包含多选项的调查问卷
  • 8.3 表单安全性和用户体验
    • 8.3.1 基础知识
    • 8.3.2 案例 1:创建具有基本验证的注册表单
    • 8.3.3 案例 2:创建一个反馈表单,具有复杂的验证
    • 8.3.4 案例 3:创建一个包含实时验证反馈的表单

8.1 数据收集与处理

8.1.1 基础知识

  • 表单的作用:表单是网站与用户互动的主要工具之一,它们用于收集用户信息、处理请求、进行搜索等。
  • 表单元素和结构:一个有效的表单包括各种输入类型如<input><textarea><select>等,以及用于提交数据的<button><input type="submit">
  • 数据的有效性:确保收集到的数据是有效和可用的,是设计表单时需要考虑的重要方面。这通常涉及到验证用户输入的数据是否符合特定格式或标准。

8.1.2 案例 1:创建一个注册表单

假设我们要创建一个用户注册表单,包括姓名、电子邮箱、密码和性别选择。

<!DOCTYPE html>
<html>
<head>
    <title>注册表单</title>
</head>
<body>
    <form action="/submit-form" method="post">
        <label for="name">姓名:</label>
        <input type="text" id="name" name="name" required><br>

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

        <label for="password">密码:</label>
        <input type="password" id="password" name="password" minlength="6" required><br>

        <label>性别:</label>
        <input type="radio" id="male" name="gender" value="male">
        <label for="male"></label>
        <input type="radio" id="female" name="gender" value="female">
        <label for="female"></label><br>

        <button type="submit">注册</button>
    </form>
</body>
</html>

8.1.3 案例 2:创建一个调查问卷表单

我们来创建一个包含多种类型输入的调查问卷表单。

<!DOCTYPE html>
<html>
<head>
    <title>调查问卷</title>
</head>
<body>
    <form action="/submit-survey" method="post">
        <label for="age">年龄:</label>
        <input type="number" id="age" name="age" min="18" max="100" required><br>

        <label for="favorite-color">喜欢的颜色:</label>
        <select id="favorite-color" name="favorite-color">
            <option value="red">红色</option>
            <option value="blue">蓝色</option>
            <option value="green">绿色</option>
        </select><br>

        <label>你喜欢编程吗?</label>
        <input type="checkbox" id="like-coding" name="like-coding" value="yes">
        <label for="like-coding"></label><br>

        <label for="feedback">反馈:</label>
        <textarea id="feedback" name="feedback" rows="4" cols="50"></textarea><br>

        <button type="submit">提交调查</button>
    </form>
</body>
</html>

8.1.4 案例 3:创建一个动态添加输入字段的表单

在这个示例中,我们将创建一个表单,用户可以根据需要添加或删除输入字段。

<!DOCTYPE html>
<html>
<head>
    <title>动态表单</title>
    <script>
        function addInputField() {
            var container = document.getElementById("inputContainer");
            var input = document.createElement("input");
            input.type = "text";
            input.name = "dynamicInput[]";
            container.appendChild(input);
            container.appendChild(document.createElement("br"));
        }
    </script>
</head>
<body>
    <form action="/submit-dynamic-form" method="post">
        <div id="inputContainer">
            <input type="text" name="dynamicInput[]"><br>
        </div>
        <button type="button" onclick="addInputField()">添加更多</button><br>
        <button type="submit">提交</button>
    </form>
</body>
</html>

通过这些案例,你将能够深入了解如何设计和处理各种类型的HTML表单,从简单的注册表单到复杂的调查问卷,再到具有动态字段的表单。这些知识不仅让你的网站功能丰富,还能提升用户的交互体验。

在这里插入图片描述


8.2 定制化表单元素

8.2.1 基础知识

  • 定制化的重要性:定制化表单元素可以提升用户体验,使你的表单更具吸引力和易用性。
  • HTML5 新元素:HTML5引入了多种新的表单元素和属性,如<range>, <date>, <time>等,它们提供了更丰富的用户界面和更好的输入体验。
  • 样式的应用:虽然我们不涉及CSS,但通过简单的HTML属性和标签选择,我们依然可以对表单元素进行一定程度的视觉定制。

8.2.2 案例 1:创建一个带有定制选择的表单

让我们构建一个带有定制化选择项的表单,包括日期选择器和范围滑块。

<!DOCTYPE html>
<html>
<head>
    <title>定制化表单元素</title>
</head>
<body>
    <form>
        <label for="appointment-date">选择日期:</label>
        <input type="date" id="appointment-date" name="appointment-date"><br>

        <label for="volume">调整音量:</label>
        <input type="range" id="volume" name="volume" min="0" max="100"><br>

        <button type="submit">提交</button>
    </form>
</body>
</html>

8.2.3 案例 2:创建一个有动态反馈的评分系统

我们将创建一个评分系统,用户可以通过选择星级来评价,同时显示实时反馈。

<!DOCTYPE html>
<html>
<head>
    <title>动态评分系统</title>
    <script>
        function updateRating(value) {
            document.getElementById('ratingValue').textContent = value;
        }
    </script>
</head>
<body>
    <form>
        <label for="rating">评分:</label>
        <input type="range" id="rating" name="rating" min="1" max="5" oninput="updateRating(this.value)">
        <span id="ratingValue">3</span>/5<br>

        <button type="submit">提交评分</button>
    </form>
</body>
</html>

8.2.4 案例 3:构建一个包含多选项的调查问卷

最后,我们来创建一个调查问卷,用户可以在其中选择多个选项。

<!DOCTYPE html>
<html>
<head>
    <title>多选项调查问卷</title>
</head>
<body>
    <form>
        <fieldset>
            <legend>选择你喜欢的运动:</legend>
            <input type="checkbox" id="sport1" name="sports" value="足球">
            <label for="sport1">足球</label><br>
            <input type="checkbox" id="sport2" name="sports" value="篮球">
            <label for="sport2">篮球</label><br>
            <input type="checkbox" id="sport3" name="sports" value="游泳">
            <label for="sport3">游泳</label><br>
        </fieldset>
        <button type="submit">提交</button>
    </form>
</body>
</html>

通过这些案例,你可以了解到表单元素定制化的不同方式,从基本的HTML5新特性到更复杂的动态交互设计。这些技巧可以帮助你打造更具吸引力和功能性的表单,从而提升整体的用户体验。

在这里插入图片描述


8.3 表单安全性和用户体验

8.3.1 基础知识

  • 表单安全性:保护用户提交的数据不受攻击是至关重要的,特别是对于包含敏感信息的表单。常见的安全措施包括验证用户输入,避免SQL注入、跨站脚本攻击(XSS)等。
  • 用户体验:一个良好的用户体验包括清晰的指示、易于理解的输入字段和友好的错误消息。这可以减少用户犯错的几率,提高表单的完成率。
  • 验证方法:简单的客户端验证可以通过HTML5的required, pattern, 和type属性来实现。更复杂的验证可能涉及JavaScript。

8.3.2 案例 1:创建具有基本验证的注册表单

构建一个注册表单,其中包括客户端验证,以确保所有字段都被正确填写。

<!DOCTYPE html>
<html>
<head>
    <title>带验证的注册表单</title>
</head>
<body>
    <form action="/submit-registration" method="post">
        <label for="username">用户名:</label>
        <input type="text" id="username" name="username" pattern="[A-Za-z0-9]{5,}" title="用户名至少5个字符,只能包含字母和数字" required><br>

        <label for="password">密码:</label>
        <input type="password" id="password" name="password" minlength="8" required><br>

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

        <button type="submit">注册</button>
    </form>
</body>
</html>

8.3.3 案例 2:创建一个反馈表单,具有复杂的验证

在这个案例中,我们创建一个反馈表单,其中包含多种类型的验证,包括文本长度和电子邮件格式。

<!DOCTYPE html>
<html>
<head>
    <title>带验证的反馈表单</title>
</head>
<body>
    <form action="/submit-feedback" method="post">
        <label for="name">姓名:</label>
        <input type="text" id="name" name="name" required><br>

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

        <label for="feedback">反馈:</label>
        <textarea id="feedback" name="feedback" minlength="20" required></textarea><br>

        <button type="submit">提交反馈</button>
    </form>
</body>
</html>

8.3.4 案例 3:创建一个包含实时验证反馈的表单

这个案例中的表单将提供实时的验证反馈,使用JavaScript来告知用户他们的输入是否符合要求。

<!DOCTYPE html>
<html>
<head>
    <title>实时验证反馈表单</title>
    <script>
        function validateInput() {
            var input = document.getElementById('username');
            var error = document.getElementById('error');
            if (input.value.length < 5) {
                error.textContent = '用户名至少需要5个字符。';
            } else {
                error.textContent = '';
            }
        }
    </script>
</head>
<body>
    <form action="/submit-form" method="post">
        <label for="username">用户名:</label>
        <input type="text" id="username" name="username" onkeyup="validateInput()"><br>
        <span id="error" style="color: red;"></span><br>

        <button type="submit">提交</button>
    </form>
</body>
</html>

通过这些案例,你可以了解到如何在HTML表单中实现基本到复杂的验证,从而提高用户体验和数据安全性。实现有效的表单验证是确保用户方便地输入数据并保护这些数据不受恶意攻击的重要步骤。

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

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

相关文章

打击者H5小游戏

欢迎来到程序小院 打击者 玩法&#xff1a;点击飞机上下左右移动躲过子弹射击&#xff0c;打掉上方敌人飞机&#xff0c; 遇到药包会增加能量&#xff0c;弹药包会升级武器&#xff0c;快去射击吧^^。开始游戏https://www.ormcc.com/play/gameStart/262 html <div id"…

点击查看 Milvus 社区十大关键词(下)

在昨天的文章《点击查看 Milvus 社区十大关键词&#xff08;上&#xff09;》中&#xff0c;我们提到将 2023 年所有 Milvus 技术交流群的聊天历史做了整理分析&#xff0c;得到了如下的一张词云图&#xff1a; 按照热度&#xff0c;排名前十的关键词依次为&#xff1a;版本、查…

游戏缺失d3dcompiler_47.dll怎么办,这五种方法可以帮你解决

d3dcompiler_47.dll文件的缺失可能会导致一系列显著且影响用户体验的问题。作为DirectX 3D编译器的重要组件&#xff0c;该动态链接库文件在许多依赖于高级图形处理的应用程序和游戏运行过程中起着至关重要的作用。当系统中缺少这个特定的dll文件时&#xff0c;可能会出现诸如应…

会话技术复习笔记

一.登录校验的需求 什么是登录校验&#xff1f; 所谓登录校验&#xff0c;指的是我们在服务器端接收到浏览器发送过来的请求之后&#xff0c;首先我们要对请求进行校验。先要校验一下用户登录了没有&#xff0c;如果用户已经登录了&#xff0c;就直接执行对应的业务操作就可以…

H264 编码标准配置档次 Profile 详解

H264 中 Profile 定义&#xff1a; H264 标准中规定了 多种档次Profile&#xff0c; 每种 Profile 都规定了一个算法特征和限制的子集&#xff0c;任何遵守某个 Profile 的解码器都应该支持与其相应的子集。维基百科中解释&#xff1a; The standard defines several sets of …

深度学习之循环神经网络 (基础)

循环神经网络简称为RNN&#xff0c;&#xff08;之前讲到的卷积神经网络简称为CNN&#xff09;。 以前我们在使用全链接网络的时候&#xff0c;我们将这种网络叫做Dense 或者是Deep。 Dense链接指的是全链接的。 我们输入的数据是数据样本的不同特征&#xff1a;x1&#xff…

STM32F407移植OpenHarmony笔记4

上一篇写到make menuconfig报错&#xff0c;继续开整。 make menuconfig需要/device/soc/*下面有对应的Kconfig文件。 直接去gitee下载stm32的配置文件拿来参考用。 先提取Kconfig文件&#xff0c;后面再添加其它文件。https://gitee.com/openharmony/device_soc_st/tree/Open…

ubuntu 22安装配置并好安全加固后,普通用户一直登录不上

现象 ubuntu 22安装配置并好安全加固后&#xff0c;普通用户一直登录不上 排查报错 查看日志/var/log/auth.log发现报错 Jan 30 15:49:57 aiv-O-E-M sshd[62570]: PAM unable to dlopen(pam_tally2.so): /lib/security/pam_tally2.so: cannot open shared object file: No …

Docker最新超详细版教程通俗易懂(基础版)

Docker概述 概念&#xff1a;容器虚拟化技术&#xff0c;系统平滑移植&#xff0c;解决了运⾏环境和配置问题的软件容 器&#xff0c;⽅便做持续集成并有助于整体发布的容器虚拟化技术 意义&#xff1a;Docker的出现使得Docker得以打破过去程序即应⽤的观念&#xff0c;透过…

详讲api网关之kong的基本概念及安装和使用(二)

consul的服务注册与发现 如果不知道consul的使用&#xff0c;可以点击上方链接&#xff0c;这是我写的关于consul的一篇文档。 upstreamconsul实现负载均衡 我们知道&#xff0c;配置upstream可以实现负载均衡&#xff0c;而consul实现了服务注册与发现&#xff0c;那么接下来…

短视频与小程序:如何实现完美结合?

在短视频日益成为人们娱乐、社交和信息获取的重要渠道的今天&#xff0c;如何在短视频平台进行小程序推广成为了许多企业和品牌关注的焦点。本文将介绍如何利用短视频平台进行小程序推广&#xff0c;提升品牌曝光和用户互动。 首先&#xff0c;打开乔拓云-门店系统的后台&#…

让AI帮你说话--GPT-SoVITS教程

有时候我们在录制视频的时候&#xff0c;由于周边环境嘈杂或者录音设备问题需要后期配音&#xff0c;这样就比较麻烦。一个比较直观的想法就是能不能将写好的视频脚本直接转换成我们的声音&#xff0c;让AI帮我们完成配音呢&#xff1f;在语音合成领域已经有很多这类工作了&…

Linux操作系统权限相关问题(一站式速通权限)

一、sudo命令 sudo yum install -y sl sudo命令的作用 不切换用户&#xff0c;就想让普通用户以root的身份&#xff0c;执行对应的指令 输入密码时&#xff0c;输入的是自己普通用户的密码&#xff0c;而不是root的密码&#xff01;&#xff01;&#xff01; sudo可以进行…

500道微信小程序毕业设计题目,小程序新颖毕业选题推荐,建议收藏

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

通过Demo学WPF—数据绑定(一)✨

前言✨ 想学习WPF&#xff0c;但是看视频教程觉得太耗时间&#xff0c;直接看文档又觉得似懂非懂&#xff0c;因此想通过看Demo代码文档的方式进行学习。 准备✨ 微软官方其实提供了WPF的一些Demo&#xff0c;地址为&#xff1a;microsoft/WPF-Samples: Repository for WPF …

仿真APP在金属波纹管液压胀形工艺设计中的应用

一、背景介绍 金属波纹管是带有波纹状截面的金属管状零件&#xff0c;在工业中应用广泛。金属波纹管特殊的截面形状使其具备较好的柔韧性&#xff0c;能够在一定范围内伸缩弯曲。这一特性赋予波纹管两大用途&#xff1a;一是作为变形补偿器&#xff0c;可用于补偿管道设备由于…

MySQL原理(三)锁定机制

一、介绍&#xff1a; 1、锁的本质 业务场景中存在共享资源&#xff0c;多个进程或线程需要竞争获取并处理共享资源&#xff0c;为了保证公平、可靠、结果正确等业务逻辑&#xff0c;要把并发执行的问题变为串行&#xff0c;串行时引入第三方锁当成谁有权限来操作共享资源的判…

Windows Server 2025 LTSC 预览版来了

Windows Server 2025 LTSC 预览版来了 1. 安装 Windows Server 2025 LTSC 预览版2. 安装 VMware Tools3. Windows Server 2025 LTSC 预览版4. Windows Server 2025 LTSC 预览版下载地址 1. 安装 Windows Server 2025 LTSC 预览版 使用 VMware Workstation 安装&#xff0c; 安…

Mysql-事务(隔离级别,事务底层原理,MVCC)

什么是事务&#xff1f;有哪些特性&#xff1f; 事务&#xff1a;事务指的是逻辑上的一组操作&#xff0c;组成这组操作的各个单元要么全都成功&#xff0c;要么全都失败。 事务特性&#xff1a; 原子性&#xff08;Atomicity&#xff09;&#xff1a; 原子性是指事务是一个不…

如何在 Ubuntu 中安装 Microsoft Edge 浏览器

微软终于聪明了一回&#xff0c;也学会了「打不过就加入」。Microsoft Edge 浏览器的 Linux 稳定版已经于 2020 年 10 月 23 日发布&#xff0c;并提供给 Linux 发行版使用。除了官方 Edge APT 源以外&#xff0c;还提供了.deb和.rpm格式的安装包。 Microsoft Edge 基于 Chrom…