news 2026/2/12 22:25:00

Vue—— Vue 3 + Element Plus 表单输入校验和自动格式化工具函数详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue—— Vue 3 + Element Plus 表单输入校验和自动格式化工具函数详解

在前端开发中,表单输入校验和格式化是一个常见但繁琐的任务。本文介绍一套完整的表单输入校验和自动格式化工具函数,帮助开发者提升用户体验并减少重复代码。

技术难点

  1. 如何自动为表单元素添加合适的属性(如最大长度、占位符等)
  2. 实现通用的数据校验机制,支持多种数据类型
  3. 动态监听 DOM 变化,为新添加的元素自动应用规则
  4. 实时显示校验错误信息并高亮错误字段

实现效果

  • 自动为不同类型的输入框添加默认属性
  • 实时校验用户输入并给出友好提示
  • 支持自定义校验规则
  • 无需手动为每个表单元素添加校验逻辑

示例演示

下面是一套完整的表单输入校验和格式化工具函数:

// 表单校验规则定义constvalidationRules={// 手机号码校验phone:{pattern:/^1[3-9]\d{9}$/,message:'请输入正确的手机号码'},// 邮箱校验email:{pattern:/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/,message:'请输入正确的邮箱地址'},// 用户名校验(4-16位字母、数字、下划线)username:{pattern:/^[a-zA-Z0-9_]{4,16}$/,message:'用户名必须是4-16位字母、数字或下划线'}};/** * 为输入元素设置默认属性 * @param {HTMLElement} element - 表单元素 */functionsetInputDefaults(element){consttagName=element.tagName.toLowerCase();consttype=element.type;// 已经处理过的元素跳过if(element._processed)return;if(tagName==='input'){// 为文本输入框添加默认最大长度和占位符if(type==='text'&&!element.hasAttribute('maxlength')){element.setAttribute('maxlength','100');if(!element.hasAttribute('placeholder')){element.setAttribute('placeholder','请输入内容');}}// 为数字输入框添加最大值限制if(type==='number'&&!element.hasAttribute('max')){element.setAttribute('max','999999999');}}if(tagName==='textarea'&&!element.hasAttribute('maxlength')){element.setAttribute('maxlength','500');element.setAttribute('rows','4');if(!element.hasAttribute('placeholder')){element.setAttribute('placeholder','请输入内容');}}// 标记为已处理element._processed=true;}/** * 显示校验错误信息 * @param {HTMLElement} element - 表单元素 * @param {string} message - 错误信息 */functionshowValidationError(element,message){// 移除已有错误提示removeValidationError(element);// 创建错误提示元素consterrorDiv=document.createElement('div');errorDiv.className='validation-error';errorDiv.textContent=message;errorDiv.style.cssText=`color: #ff4d4f; font-size: 12px; margin-top: 4px;`;// 高亮错误字段element.style.borderColor='#ff4d4f';// 插入错误提示element.parentNode.appendChild(errorDiv);element._errorElement=errorDiv;}/** * 移除校验错误信息 * @param {HTMLElement} element - 表单元素 */functionremoveValidationError(element){if(element._errorElement){element._errorElement.remove();element._errorElement=null;element.style.borderColor='';}}/** * 添加输入校验功能 * @param {HTMLElement} element - 表单元素 */functionaddInputValidation(element){constdataType=element.getAttribute('data-type');if(!dataType||!validationRules[dataType])return;// 创建校验处理函数constvalidationHandler=(event)=>{constvalue=event.target.value.trim();// 移除之前错误提示removeValidationError(element);// 空值不校验if(!value)return;construle=validationRules[dataType];if(!rule.pattern.test(value)){showValidationError(element,rule.message);}};// 绑定事件element.addEventListener('blur',validationHandler);element.addEventListener('input',validationHandler);// 保存引用便于清理element._validationHandler=validationHandler;}/** * 初始化表单校验功能 */exportfunctioninitFormValidation(){// 使用 MutationObserver 监听 DOM 变化constobserver=newMutationObserver((mutations)=>{mutations.forEach((mutation)=>{if(mutation.type==='childList'){mutation.addedNodes.forEach((node)=>{if(node.nodeType===Node.ELEMENT_NODE){// 处理新添加的表单元素if(isFormElement(node)){setInputDefaults(node);addInputValidation(node);}// 处理子元素中的表单元素constformElements=node.querySelectorAll?node.querySelectorAll('input, textarea'):[];formElements.forEach((element)=>{setInputDefaults(element);addInputValidation(element);});}});}});});// 开始观察 DOM 变化observer.observe(document.body,{childList:true,subtree:true});// 处理已存在的表单元素functionprocessExistingElements(){constelements=document.querySelectorAll('input, textarea');elements.forEach((element)=>{setInputDefaults(element);addInputValidation(element);});}// 页面加载完成后处理现有元素if(document.readyState==='loading'){document.addEventListener('DOMContentLoaded',processExistingElements);}else{processExistingElements();}}/** * 判断是否为表单元素 * @param {HTMLElement} element - 元素 * @returns {boolean} */functionisFormElement(element){consttagName=element.tagName.toLowerCase();returntagName==='input'||tagName==='textarea';}

解决方案

这套工具函数的核心思想是:

  1. 自动属性设置:通过 [setInputDefaults](file:///E:/project/front/src/utils/global-util.js#L43-L87) 函数为不同类型的表单元素自动添加合适的默认属性,如最大长度、占位符等。

  2. 灵活校验规则:通过 [validationRules](file:///E:/project/front/src/utils/regExp-util.js#L12-L47) 对象定义各种校验规则,支持扩展自定义规则。

  3. 实时校验反馈:通过 [addInputValidation](file:///E:/project/front/src/utils/global-util.js#L122-L172) 函数为表单元素添加失焦和输入事件监听器,实现实时校验。

  4. 动态元素支持:使用 [MutationObserver](file:///E:/project/front/src/utils/global-util.js#L243-L294) 监听 DOM 变化,为动态添加的表单元素自动应用校验规则。

  5. 友好的错误提示:通过 [showValidationError](file:///E:/project/front/src/utils/global-util.js#L179-L202) 和 [removeValidationError](file:///E:/project/front/src/utils/global-util.js#L209-L221) 函数提供直观的错误提示和视觉反馈。

使用方式非常简单,只需在应用初始化时调用 [initFormValidation()](file:///E:/project/front/src/utils/global-util.js#L342-L375) 函数,并在需要校验的表单元素上添加data-type属性:

<inputtype="text"data-type="phone"/><inputtype="text"data-type="email"/><textareadata-type="username"></textarea>

这样就能自动获得完整的表单校验和格式化功能,大大减少了手动编写校验逻辑的工作量。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/6 18:28:26

Python 3.13类型提示重大更新(类型安全新纪元)

第一章&#xff1a;Python 3.13类型提示重大更新&#xff08;类型安全新纪元&#xff09;Python 3.13 在类型系统方面引入了多项突破性改进&#xff0c;显著增强了静态类型检查的能力与灵活性&#xff0c;标志着 Python 向类型安全的新纪元迈出了关键一步。这些更新不仅提升了开…

作者头像 李华
网站建设 2026/2/10 22:34:38

Python自动化测试工具终极指南:快速掌握Selenium浏览器控制技术

Python自动化测试工具终极指南&#xff1a;快速掌握Selenium浏览器控制技术 【免费下载链接】callPhoneBoom 最新可用&#xff01;&#xff01;&#xff01;夺命百连呼、电话轰炸、电话攻击(电话轰炸、可代替短信轰炸)、留言攻击工具 项目地址: https://gitcode.com/gh_mirro…

作者头像 李华
网站建设 2026/2/12 13:41:15

DGL-KE知识图谱嵌入终极指南:如何快速掌握高性能分布式训练

DGL-KE知识图谱嵌入终极指南&#xff1a;如何快速掌握高性能分布式训练 【免费下载链接】dgl-ke High performance, easy-to-use, and scalable package for learning large-scale knowledge graph embeddings. 项目地址: https://gitcode.com/gh_mirrors/dg/dgl-ke 知识…

作者头像 李华
网站建设 2026/2/12 15:41:58

如何快速获取高通QCA7005:开发者的终极指南

如何快速获取高通QCA7005&#xff1a;开发者的终极指南 【免费下载链接】高通QCA7005数据手册下载 高通QCA7005数据手册下载本仓库提供高通QCA7005数据手册&#xff08;qca7005_data_sheet.pdf&#xff09;的下载 项目地址: https://gitcode.com/Open-source-documentation-t…

作者头像 李华
网站建设 2026/2/6 13:46:06

打造极致有声书体验:BookPlayer全方位解析

打造极致有声书体验&#xff1a;BookPlayer全方位解析 【免费下载链接】BookPlayer Player for your DRM-free audiobooks 项目地址: https://gitcode.com/gh_mirrors/bo/BookPlayer 在数字阅读时代&#xff0c;有声书正成为越来越多人获取知识的首选方式。今天要介绍的…

作者头像 李华
网站建设 2026/2/12 4:40:53

终极指南:快速掌握 Wav2Vec2-Large-XLSR-53-English 语音识别模型

终极指南&#xff1a;快速掌握 Wav2Vec2-Large-XLSR-53-English 语音识别模型 【免费下载链接】wav2vec2-large-xlsr-53-english 项目地址: https://ai.gitcode.com/hf_mirrors/jonatasgrosman/wav2vec2-large-xlsr-53-english 还在为语音转文字而烦恼吗&#xff1f;Wa…

作者头像 李华