Vue3输入框没有输入内容时进行文字提示,输入文字自动消失

**先看效果:**当输入框为空或者不符合要求是在输入框下方进行文字提示,检测到有输入内容则提示消失

1.html

要用到:class动态绑定样式和@input检测输入框状态,看代码

html 复制代码
<el-input
    v-model="diauser"
    style="margin-bottom: 20px; width: 70%"
    placeholder="请输入账户"
    :prefix-icon="Avatar"
    clearable
    :class="{ error: diauserError }"
    @input="checkInput"
    ></el-input>
<small v-if="diauserError" class="error-message">账户不能为空且由6-16位字母、数字、下划线组成</small>

因为我写了多个输入框,所以我没有用div进行包裹,选择直接在el-input标签下直接使用span,但我想要的小字体所有把span换成了small**(** 但在css中也做了字体大小修改**)**

2.js

js部分要定义为false,默认提示语为关闭状态

methods中代码为,使用管道符|| 进行逻辑判断的连接 (||==or或者)

javascript 复制代码
if (
   this.diauser.trim() === "" ||
   !/(?=.*[A-Za-z_])[A-Za-z0-9_]{6,16}$/.test(this.diauser)
   ) {
     this.diauserError = true;
   }

还有一个检测输入框状态的方法

当点击输入框时触发checkInput方法,this.diauser.trim()会检查this.diauser是否为空或者不符合设定预期,this.diauserError是上方设置的布尔值,不符合预期就是true,其余都默认为false

3.css

定义提示语字体颜色、大小(格式)等

css 复制代码
.error-message {
  color: red;
  font-size: 12px;
  margin-top: -20px;
}

如有错误,欢迎指正~!

相关推荐
zhuyan10828 分钟前
Linux 系统磁盘爆满导致无法启动修复指南
前端·chrome
编程牛马姐1 小时前
独立站SEO流量增长:提高Google排名的优化方法
前端·javascript·网络
NotFound4861 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
Dontla1 小时前
高基数(High Cardinality)问题介绍(Prometheus、高基数字段、低基数字段)
前端·数据库·prometheus
一 乐3 小时前
医院挂号|基于springboot + vue医院挂号管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·医院挂号管理系统
whuhewei4 小时前
为什么客户端不存在跨域问题
前端·安全
妮妮喔妮4 小时前
supabase的webhook报错
开发语言·前端·javascript
qq_12084093714 小时前
Three.js 大场景分块加载实战:从全量渲染到可视集调度
开发语言·javascript·数码相机
yivifu5 小时前
手搓HTML双行夹批效果
前端·html·html双行夹注
奔跑的卡卡5 小时前
Web开发与AI融合-第一篇:Web开发与AI融合的时代序幕
前端·人工智能