前端零基础入门到上班:Day7——表单系统实战全解析
🧩前端零基础入门到上班:Day7——表单系统实战全解析
✅ 目标:不仅掌握 HTML 表单标签,更深入理解其在实战中的作用、验证方式、美化技巧与 JS 联动,为后续接入 Vue、后端接口打下坚实基础。
🌟 一、HTML 表单基础标签全讲解
🧱 1.1 <form> 是什么?为什么重要?
- 所有表单控件必须写在
<form>中才能统一提交。 action:指定提交地址(可以是接口 URL)method:提交方式,常用 GET / POSTenctype:上传文件时设置为multipart/form-data
<form action="/api/register" method="post" enctype="multipart/form-data"><!-- 表单控件写在这里 -->
</form>
🧰 1.2 表单核心控件分类总览
| 控件 | 标签 | 常见用途 | 特点说明 |
|---|---|---|---|
| 单行输入 | <input> | 用户名、密码等 | 多类型支持 |
| 多行输入 | <textarea> | 评论、简介 | 手动设置行列 |
| 下拉框 | <select> | 性别、城市选择 | 可选项配合 <option> |
| 单选框 | <input type="radio"> | 性别选择 | 同组需 name 一致 |
| 多选框 | <input type="checkbox"> | 爱好选择 | value 必设 |
| 文件上传 | <input type="file"> | 上传头像 | 需配合 enctype |
| 提交按钮 | <button> / <input type="submit"> | 提交表单 | type 属性控制行为 |
✨ 1.3 常用 <input> 类型深度实践
<form><input type="text" name="username" placeholder="用户名" required><input type="password" name="pwd" placeholder="密码" minlength="6" required><input type="email" name="email" placeholder="邮箱" required><input type="tel" name="phone" pattern="1[3-9]\d{9}" placeholder="手机号" title="请输入合法手机号"><input type="url" name="homepage" placeholder="个人主页 URL"><input type="date" name="birthday"><input type="file" name="avatar" accept="image/*">
</form>
🎯 注意点:
required为原生验证,不填无法提交pattern支持正则校验- 多选用
name="hobby[]"来表示数组参数
🧪 二、实战:注册 + 登录 + 留言系统
📋 2.1 注册表单:多字段布局 + 美化
<form id="registerForm"><label>用户名</label><input type="text" name="username" required><label>密码</label><input type="password" name="password" required><label>性别</label><select name="gender"><option value="male">男</option><option value="female">女</option></select><label>上传头像</label><input type="file" name="avatar"><button type="submit">注册</button>
</form>
💄 表单美化(核心样式)
form {width: 100%;max-width: 500px;margin: auto;display: flex;flex-direction: column;gap: 12px;background: #f5f5f5;padding: 20px;border-radius: 10px;
}
input, select, button {padding: 10px;border: 1px solid #ccc;border-radius: 6px;
}
button {background-color: #0066ff;color: white;cursor: pointer;
}
🔐 2.2 登录系统:带记住我功能
<form id="loginForm"><input type="text" name="username" placeholder="用户名" required><input type="password" name="password" placeholder="密码" required><label><input type="checkbox" name="remember"> 记住我</label><button type="submit">登录</button>
</form>
💬 2.3 留言板表单:textarea + 表单提交
<form id="commentForm"><label>昵称</label><input type="text" name="nickname" required><label>留言内容</label><textarea name="content" rows="4" required></textarea><button type="submit">提交留言</button>
</form>
🛡️ 三、前端验证:原生 + JavaScript 双管齐下
🔍 3.1 原生验证小结
| 验证方式 | 说明 |
|---|---|
required | 是否必填 |
pattern | 正则表达式 |
minlength/maxlength | 长度限制 |
type=email / tel / url | 格式自动验证 |
✨ 3.2 JS 自定义验证逻辑
<script>
document.getElementById("registerForm").addEventListener("submit", function(e) {const username = this.username.value;const pwd = this.password.value;if (username.length < 3) {alert("用户名至少3位!");e.preventDefault();}if (pwd.length < 6) {alert("密码至少6位!");e.preventDefault();}
});
</script>
📡 四、与后端交互机制深入理解
📮 4.1 GET 与 POST 提交差异
| 提交方式 | 特点 | 示例 |
|---|---|---|
| GET | 参数在 URL 中 | /api?user=aaa&pwd=123 |
| POST | 参数在请求体中 | 后端通过 body 获取 |
📦 4.2 使用 fetch 模拟表单异步提交
<script>
document.getElementById("loginForm").addEventListener("submit", function(e) {e.preventDefault();const formData = new FormData(this);fetch('/api/login', {method: 'POST',body: formData}).then(res => res.json()).then(data => {alert("登录结果:" + data.message);});
});
</script>
🎨 五、表单美化 + 响应式设计技巧
@media screen and (max-width: 600px) {form {padding: 10px;}input, select, button {font-size: 14px;}
}
🧠 六、易错点总结 + 进阶拓展
<label for="">中for属性值应与input id匹配,否则点击无效- 不要遗漏
name属性,否则数据不会被提交 type="submit"才能触发表单默认提交行为- 文件上传必须设置
enctype="multipart/form-data"
🎯 Day7 小结
✅ 你已经掌握了:
- 表单标签、控件及其语法
- 表单场景构建(注册、登录、留言)
- 验证逻辑全流程(原生 + JS)
- 提交机制(GET / POST + fetch)
- 响应式样式编写与优化
📢 明日预告:Day8 —— JavaScript 入门 + 表单动态交互
📩 如果你在学习表单过程中有不理解的地方,欢迎随时私信我。支持1v1代码查看、调试协助、项目整合答疑,助你从入门无阻碍过渡到实战。
🔥 系列持续更新,关注我不迷路!
📩 有问题可以 私信我1v1
相关文章:
前端零基础入门到上班:Day7——表单系统实战全解析
🧩前端零基础入门到上班:Day7——表单系统实战全解析 ✅ 目标:不仅掌握 HTML 表单标签,更深入理解其在实战中的作用、验证方式、美化技巧与 JS 联动,为后续接入 Vue、后端接口打下坚实基础。 🌟 一、HTML 表…...
【特殊场景应对1】视觉设计:信息密度与美学的博弈——让简历在HR视网膜上蹦迪的科学指南
写在最前 作为一个中古程序猿,我有很多自己想做的事情,比如埋头苦干手搓一个低代码数据库设计平台(目前只针对写java的朋友),比如很喜欢帮身边的朋友看看简历,讲讲面试技巧,毕竟工作这么多年,也做到过高管,有很多面人经历,意见还算有用,大家基本都能拿到想要的offe…...
o3和o4-mini的升级有哪些亮点?
ChatGPT是基于OpenAI GPT系列的高性能对话生成AI,经过多代迭代不断提升自然语言理解和生成能力。 在过去的一年中,OpenAI先后发布了GPT-4、GPT‑4.1及多种mini版本,为不同使用场景提供灵活选择。 随着用户需求向更高效、更精准的推理和视觉…...
影楼精修行业浅见-序言
影楼及商业摄影行业对高效、智能化的图像精修需求日益增长。传统修图流程耗时长、人工成本高,且修图师水平参差不齐影响最终成片质量。AI驱动的影像精修软件通过自动化、批量处理和智能算法,显著提升了修片效率和一致性,成为影楼数字化升级的…...
MATLAB 控制系统设计与仿真 - 36
鲁棒工具箱定义了个新的对象类ureal,可以定义在某个区间内可变的变量。 函数的调用格式为: p ureal(name,nominalvalue) % name为变量名,nominalValue为标称值,默认变化值为/-1 p ureal(name,nominalvalue,PlusMinus,plusminus) p ureal(name,nomin…...
Spring数据访问全解析:ORM整合与JDBC高效实践
目录 一、Spring ORM集成深度剖析 🌟 ORM模块架构设计 核心集成特性: 整合MyBatis示例配置: 二、Spring JDBC高效实践指南 🌟 传统JDBC vs Spring JDBC对比 🌟 JdbcTemplate核心操作示例 批量操作优化…...
【HCIA】使用Access port实现简易的VLAN间通信
前言 当我们拥有一台三层交换机与两个vlan,我们可以使用简易的Vlanif配置实现VLAN间通信。 文章目录 前言1. 拓扑图2. 配置交换机3. 配置PC1与PC2的网络4. port link-type后记修改记录 1. 拓扑图 2. 配置交换机 <Huawei>system-view [Huawei]undo info-cent…...
6.VTK 颜色
文章目录 概念RGB示例HSV示例 概念 RGB颜色系统:通过红(R)、绿(G)、蓝(B)三个颜色分量的组合来定义颜色。每个分量的取值范围是0到1,其中(0, 0, 0)代表黑色,而(1, 1, 1)代表白色。可以使用vtkProperty::SetColor(r, g, b)方法为Actor设置颜色…...
shiro使用
shiro是apache提供的一种安全框架。他可以将登录,权限这一方面简单化。 使用shiro需要引入 <dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-core</artifactId><version>1.9.0</version></depend…...
光谱相机的成像方式
光谱相机的成像方式决定了其如何获取物体的空间与光谱信息,核心在于分光技术与扫描模式的结合。以下是主要成像方式的分类解析: 一、滤光片切换型 1. 滤光片轮(Filter Wheel) 原理:通过旋转装有多个窄带…...
浅析MySQL事务锁
在 MySQL 中,事务锁是用于确保数据一致性和并发控制的重要机制。事务锁可以帮助防止多个事务同时修改同一数据,从而避免数据不一致和脏读、不可重复读、幻读等问题。 以下是 MySQL 事务锁的关键点总结: 事务锁:用于确保数据一致性和并发控制。锁的类型: 行级锁:InnoDB,粒…...
算法-链表
小细节 初始化问题 我们这样子new一个ListNode 它里面的默认值是0,所以我们不能这样 如果我们为空,我们要返回null 节点结束条件判断(多创建节点问题) 参考示例3217 解析: 我的答案是多了一个无用节点 这是因为我每…...
ON DUPLICATE KEY UPDATE 更底层解释它的优势
从更底层来看,ON DUPLICATE KEY UPDATE 的优势主要源于以下几个方面: 1. 减少网络往返次数 先查询再更新:这种方式需要客户端和数据库服务器之间进行多次网络通信。首先,客户端发送一个 SELECT 查询请求,然后等待服务…...
3.8/Q1,GBD数据库最新文章解读
文章题目:Regional and National Burden of Traumatic Brain Injury and Spinal Cord Injury in North Africa and Middle East Regions, 1990-2021: A Systematic Analysis for The Global Burden of Disease Study 2021 DOI:10.1007/s44197-025-00372-…...
51单片机实验二:数码管静态显示
目录 一、实验环境与实验器材 二、实验内容及实验步骤 1.单个数码管显示 2.六个数码管依次从0~F变换显示 3.proteus仿真 一、实验环境与实验器材 环境:Keli,STC-ISP烧写软件,Proteus. 器材:TX-1C单片机(STC89C52RC…...
Linux驱动开发进阶(八)- GPIO子系统BSP驱动
文章目录 1、前言2、pinctrl子系统3、pinctrl bsp驱动4、gpio子系统5、gpio bsp驱动 1、前言 学习参考书籍以及本文涉及的示例程序:李山文的《Linux驱动开发进阶》本文属于个人学习后的总结,不太具备教学功能。 2、pinctrl子系统 在讨论gpio子系统时&…...
【Windows】安装或者点击OneDrive没有任何反应的解决方案
一些Windows企业版或者神州网信政府版的策略会禁止使用OneDrive,双击OneDrive安装程序或者点击OneDrive软件会没有任何反应。通过下面的设置可以解除相关的限制。 1、修改注册表 打开注册表管理器。依次HKEYLOCAL_MACHINE\Software\Policies\Microsoft\Windows\One…...
Android tinyalsa库函数剖析
1. PCM 流控制函数 打开、关闭及状态检查 pcm_open(unsigned int card, unsigned int device, unsigned int flags, struct pcm_config *config) 打开指定声卡(card)和设备(device)的 PCM 流。 flags 参数确定流的方向࿱…...
PyCharm Flask 使用 Tailwind CSS v3 配置
安装 Tailwind CSS 步骤 1:初始化项目 在 PyCharm 终端运行:npm init -y安装 Tailwind CSS:npm install -D tailwindcss3 postcss autoprefixer初始化 Tailwind 配置文件:npx tailwindcss init这会生成 tailwind.config.js。 步…...
Python爬虫第17节-动态渲染页面抓取之Selenium使用下篇
目录 引言 一、获取节点信息 1.1 获取属性 1.2 获取文本值 1.3 获取ID、位置、标签名、大小 二、切换Frame 三、延时等待 3.1 隐式等待 3.2 显式等待 四、前进后退 五、Cookies 六、选项卡管理 七、异常处理 引言 这一节我们继续讲解Selenium的使用下篇࿰…...
HarmonyOS 第2章 Ability的开发,鸿蒙HarmonyOS 应用开发入门
第2章 Ability的开发 本章内容 本章介绍HarmonyOS的核心组件Ability的开发。 2.1 Ability概述 2.2 FA模型介绍 2.3 Stage模型介绍 2.4 Ability内页面的跳转和数据传递 2.5 Want概述 2.6 实战:显式Want启动Ability 2.7 实战:隐式Want打开应用管理 2.8 小结 2.9 习题 2.1 Abili…...
day2-小白学习JAVA---java第一个程序
java第一个程序 1、新建一个文件,以.java为结尾2、用编辑器打开后写入代码(本人写前端,所以用vscode,也可用其他)3、编译文件4、运行文件5、HelloWorld代码解释6、文档注释 1、新建一个文件,以.java为结尾 …...
Rockchip 新一代 64 位处理器 RK3562--九鼎开发板
RK3562 是 Rockchip 新一代 64 位处理器 RK3562(Quad-core ARM Cortex-A53,主频 最高 2.0GHz),最大支持 8GB 内存;内置独立的 NPU,可用于轻量级人工智能应用,RK3562 拥有 PCIE2.1/USB3.0 OTG/…...
z-library电子图书馆最新地址的查询方法
对于喜欢读书的伙伴们,应该都听说过z站(z-library),优点多多,缺点就是地址不稳定,经常会变化网站地址。然后我最近发现了一个工具,可以不间断更新官方可用的z站地址:电子书最新地址...
常见MQ及类MQ对比:Redis Stream、Redis Pub/Sub、RocketMQ、Kafka 和 RabbitMQ
常见MQ及类MQ对比 基于Grok调研 Redis Stream、Redis Pub/Sub、RocketMQ、Kafka 和 RabbitMQ 关键点: Redis Pub/Sub 适合简单实时消息,但不持久化,消息可能丢失。Redis Stream 提供持久化,适合需要消息历史的场景,但…...
Kaggle-Bag of Words Meets Bags of Popcorn-(二分类+NLP+Bert模型)
Bag of Words Meets Bags of Popcorn 题意: 有很多条电影评论记录,问你每一条记录是积极性的评论还是消极性的评论。 数据处理: 1.首先这是文件是zip形式,要先解压,注意sep ‘\t’。 2.加载预训练的 BERT 分词器 …...
Spring Boot 3 + SpringDoc:打造接口文档
1、背景公司 新项目使用SpringBoot3.0以上构建,其中需要对外输出接口文档。接口文档一方面给到前端调试,另一方面给到测试使用。 2、SpringDoc 是什么? SpringDoc 是一个基于 Spring Boot 项目的库,能够自动根据项目中的配置、…...
Json 在线格式化 - 加菲工具
Json 在线格式化 打开网站 加菲工具 选择“Json 在线格式化” 或者直接进入 https://www.orcc.top/tools/json 输入Json,点击左上角的“格式化”按钮 得到格式化后的结果...
React 列表渲染基础示例
React 中最常见的一个需求就是「把一组数据渲染成一组 DOM 元素」,比如一个列表。下面是我写的一个最小示例,目的是搞清楚它到底是怎么工作的。 示例代码 // 定义一个静态数组,模拟后续要渲染的数据源 // 每个对象代表一个前端框架…...
HarmonyOS-ArkUI V2装饰器: @Monitor装饰器:状态变量修改监听
Monitor作用 Monitor的作用就是来监听状态变量的值变化的。被Monitor修饰的函数,会在其对应监听的变量发生值的变化时,回调此函数,从而可以让您知道是什么值发生变化了,变化前是什么值,变化后是什么值。 V1版本的装饰器,有个叫@Watch的装饰器,其实也有监听变化的能力,…...
