用vue3写一个功能:点击登录按钮,自动校验账号框和密码框,为空则给出提示“账号或密码不能为空!”,并判断账号(11位手机号)和密码(8-20位数字和字母)是否正确,,不正确则提示“用户名和密码错误!”要求美观一点

时间: 2023-12-18 19:02:24 浏览: 71
以下是一个简单的示例代码,使用了Vue3的Composition API来实现: ```html <template> <div class="login-form"> <h2>登录</h2> <form @submit.prevent="submitForm"> <div class="form-group"> <label for="username">账号</label> <input type="text" id="username" v-model="username" placeholder="请输入11位手机号码" /> </div> <div class="form-group"> <label for="password">密码</label> <input type="password" id="password" v-model="password" placeholder="请输入8-20位数字和字母" /> </div> <div class="form-group"> <button type="submit">登录</button> </div> </form> <div v-if="errorMessage" class="error-message">{{ errorMessage }}</div> </div> </template> <script> import { ref } from 'vue'; export default { setup() { const username = ref(''); const password = ref(''); const errorMessage = ref(''); const submitForm = () => { if (!username.value || !password.value) { errorMessage.value = '账号或密码不能为空!'; return; } const phoneRegex = /^1\d{10}$/; const passwordRegex = /^[a-zA-Z0-9]{8,20}$/; if (!phoneRegex.test(username.value) || !passwordRegex.test(password.value)) { errorMessage.value = '用户名和密码错误!'; return; } // TODO: 发送登录请求 errorMessage.value = ''; }; return { username, password, errorMessage, submitForm, }; }, }; </script> <style scoped> .login-form { max-width: 400px; margin: 0 auto; padding: 20px; border: 1px solid #ccc; border-radius: 5px; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3); } .form-group { margin-bottom: 10px; } label { display: block; margin-bottom: 5px; } input[type="text"], input[type="password"] { width: 100%; padding: 8px; border: 1px solid #ccc; border-radius: 3px; } button[type="submit"] { background-color: #4CAF50; color: #fff; padding: 8px 16px; border: none; border-radius: 3px; cursor: pointer; transition: background-color 0.2s; } button[type="submit"]:hover { background-color: #3e8e41; } .error-message { color: red; margin-top: 10px; } </style> ``` 在这个示例代码中,我们使用了Vue3的Composition API来编写组件逻辑。`ref`函数用于创建响应式数据,我们使用它来创建`username`、`password`和`errorMessage`变量。 我们在模板中使用了`v-model`指令来双向绑定输入框的值,使用`@submit`事件监听表单提交事件,调用`submitForm`方法来处理登录逻辑。 `submitForm`方法首先检查账号和密码是否为空,如果为空则设置`errorMessage`为相应的提示信息并返回。然后使用正则表达式检查账号和密码是否符合格式要求,如果不符合则同样设置`errorMessage`为相应的提示信息并返回。 最后,如果账号和密码都符合要求,我们可以发送登录请求,并清空`errorMessage`以便下次使用。如果你需要根据具体的业务逻辑来处理登录请求,可以在TODO注释下面编写相应的代码。 最后,我们使用了一些简单的CSS样式来美化表单,包括设置表单宽度、边框、圆角、阴影等等。同时,我们也为错误提示信息设置了一个红色颜色。

相关推荐

最新推荐

recommend-type

详解用vue编写弹出框组件

Vue 弹出框组件设计实现 在本篇文章中,我们将详细讲解使用 Vue 编写弹出...我们讨论了两种实现方法的优缺点,并给出了一个简单的弹出框组件的实现代码。希望本篇文章能够帮助您更好地理解 Vue 弹出框组件的设计实现。
recommend-type

vue实现点击按钮切换背景颜色的示例代码

`getMoney`方法用于更新`dynamic`的值,使得每次点击一个按钮,只有被点击的按钮拥有`colorChange`类,其他按钮的背景颜色恢复原状。 6. **总结**:Vue的响应式系统使得我们在数据变化时可以自动更新视图。通过绑定...
recommend-type

前端vue+elementUI如何实现记住密码功能

在前端开发中,实现“记住密码”功能是一个常见的需求,特别是在用户登录界面。Vue.js结合Element UI组件库可以轻松地创建交互式用户界面。本文将详细介绍如何使用Vue和Element UI来实现这一功能,主要依赖于浏览器...
recommend-type

vue 实现用户登录方式的切换功能

在Vue.js开发中,用户登录方式的切换是一个常见的需求,特别是在多模式登录的场景下。本文将深入探讨如何在Vue中实现这个功能,通过实例代码详细讲解,帮助开发者理解和实践。 首先,我们需要在Vue组件的数据(data...
recommend-type

vue项目中使用AES实现密码加密解密(ECB和CBC两种模式)

在Vue项目中,为了保护用户数据的安全,常常需要对敏感信息如密码进行加密处理。AES(Advanced Encryption Standard)是一种广泛使用的对称加密算法,能够提供高效且安全的数据加密。本篇将详细介绍如何在Vue项目中...
recommend-type

BSC绩效考核指标汇总 (2).docx

BSC(Balanced Scorecard,平衡计分卡)是一种战略绩效管理系统,它将企业的绩效评估从传统的财务维度扩展到非财务领域,以提供更全面、深入的业绩衡量。在提供的文档中,BSC绩效考核指标主要分为两大类:财务类和客户类。 1. 财务类指标: - 部门费用的实际与预算比较:如项目研究开发费用、课题费用、招聘费用、培训费用和新产品研发费用,均通过实际支出与计划预算的百分比来衡量,这反映了部门在成本控制上的效率。 - 经营利润指标:如承保利润、赔付率和理赔统计,这些涉及保险公司的核心盈利能力和风险管理水平。 - 人力成本和保费收益:如人力成本与计划的比例,以及标准保费、附加佣金、续期推动费用等与预算的对比,评估业务运营和盈利能力。 - 财务效率:包括管理费用、销售费用和投资回报率,如净投资收益率、销售目标达成率等,反映公司的财务健康状况和经营效率。 2. 客户类指标: - 客户满意度:通过包装水平客户满意度调研,了解产品和服务的质量和客户体验。 - 市场表现:通过市场销售月报和市场份额,衡量公司在市场中的竞争地位和销售业绩。 - 服务指标:如新契约标保完成度、续保率和出租率,体现客户服务质量和客户忠诚度。 - 品牌和市场知名度:通过问卷调查、公众媒体反馈和总公司级评价来评估品牌影响力和市场认知度。 BSC绩效考核指标旨在确保企业的战略目标与财务和非财务目标的平衡,通过量化这些关键指标,帮助管理层做出决策,优化资源配置,并驱动组织的整体业绩提升。同时,这份指标汇总文档强调了财务稳健性和客户满意度的重要性,体现了现代企业对多维度绩效管理的重视。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【进阶】Flask中的会话与用户管理

![python网络编程合集](https://media.geeksforgeeks.org/wp-content/uploads/20201021201514/pythonrequests.PNG) # 2.1 用户注册和登录 ### 2.1.1 用户注册表单的设计和验证 用户注册表单是用户创建帐户的第一步,因此至关重要。它应该简单易用,同时收集必要的用户信息。 * **字段设计:**表单应包含必要的字段,如用户名、电子邮件和密码。 * **验证:**表单应验证字段的格式和有效性,例如电子邮件地址的格式和密码的强度。 * **错误处理:**表单应优雅地处理验证错误,并提供清晰的错误消
recommend-type

卷积神经网络实现手势识别程序

卷积神经网络(Convolutional Neural Network, CNN)在手势识别中是一种非常有效的机器学习模型。CNN特别适用于处理图像数据,因为它能够自动提取和学习局部特征,这对于像手势这样的空间模式识别非常重要。以下是使用CNN实现手势识别的基本步骤: 1. **输入数据准备**:首先,你需要收集或获取一组带有标签的手势图像,作为训练和测试数据集。 2. **数据预处理**:对图像进行标准化、裁剪、大小调整等操作,以便于网络输入。 3. **卷积层(Convolutional Layer)**:这是CNN的核心部分,通过一系列可学习的滤波器(卷积核)对输入图像进行卷积,以
recommend-type

BSC资料.pdf

"BSC资料.pdf" 战略地图是一种战略管理工具,它帮助企业将战略目标可视化,确保所有部门和员工的工作都与公司的整体战略方向保持一致。战略地图的核心内容包括四个相互关联的视角:财务、客户、内部流程和学习与成长。 1. **财务视角**:这是战略地图的最终目标,通常表现为股东价值的提升。例如,股东期望五年后的销售收入达到五亿元,而目前只有一亿元,那么四亿元的差距就是企业的总体目标。 2. **客户视角**:为了实现财务目标,需要明确客户价值主张。企业可以通过提供最低总成本、产品创新、全面解决方案或系统锁定等方式吸引和保留客户,以实现销售额的增长。 3. **内部流程视角**:确定关键流程以支持客户价值主张和财务目标的实现。主要流程可能包括运营管理、客户管理、创新和社会责任等,每个流程都需要有明确的短期、中期和长期目标。 4. **学习与成长视角**:评估和提升企业的人力资本、信息资本和组织资本,确保这些无形资产能够支持内部流程的优化和战略目标的达成。 绘制战略地图的六个步骤: 1. **确定股东价值差距**:识别与股东期望之间的差距。 2. **调整客户价值主张**:分析客户并调整策略以满足他们的需求。 3. **设定价值提升时间表**:规划各阶段的目标以逐步缩小差距。 4. **确定战略主题**:识别关键内部流程并设定目标。 5. **提升战略准备度**:评估并提升无形资产的战略准备度。 6. **制定行动方案**:根据战略地图制定具体行动计划,分配资源和预算。 战略地图的有效性主要取决于两个要素: 1. **KPI的数量及分布比例**:一个有效的战略地图通常包含20个左右的指标,且在四个视角之间有均衡的分布,如财务20%,客户20%,内部流程40%。 2. **KPI的性质比例**:指标应涵盖财务、客户、内部流程和学习与成长等各个方面,以全面反映组织的绩效。 战略地图不仅帮助管理层清晰传达战略意图,也使员工能更好地理解自己的工作如何对公司整体目标产生贡献,从而提高执行力和组织协同性。