css实现input表单验证
有没有办法只通过css来确定input标签能否有输入?
我有这个想法是由于我想完成一个自动补全的input部件,最基本的功能是:
- 假如input没有内容,这隐藏下拉框
- 反之,显示下拉框
我找到了一个也许不是很完美的实现方案,形容中可能会有少量细微的区别,不过我还是很希望能做这个简单的分享
首先,我们构造一个简单的form表单,仅仅只有一个input
<form> <label for="input">输入框</label> <input type="text" id="input"/></form>当输入少量值,我设置input的边框颜色为绿的,下面是一个例子:
gif
判断input能否为空
我通过html表单验证去判断能否为空,所以,这里我使用了required属性
<form> <label> Input </label> <input type="text" name="input" id="input" required /></form>// valid:当input输入值也合法值时采用的样式#input:valid{ border-color: green;}这时,当有输入的时候,input体现的很好,边框颜色也有了相应的变化:
gif
但是,这里有个问题,假如客户输入的是空格,那么边框颜色也会发生改变。
[站外图片上传中…(image-9adfa1-1575421399819)]
原理上看,这种体现是正常的,由于输入框的确有了内容。
但是,实际上,我不想让空格来触发自动补全弹窗
所以这还不能满足我们的需求,我要做更细致的检查
进一步完善
html提供我们利用正则去验证输入框内容的属性:pattern,这里也尝试使用该属性来完善
由于想把空格视为非法输入,我使用\S+,这个很简单,匹配一个或者者多个任何非空白字符
<form> <label> Input </label> <input type="text" name="input" id="input" required pattern="\S+"/></form>使用这种方式,确实见效了,假如客户输入空格,输入框没有任何变化
[站外图片上传中…(image-78ad31-1575421399819)]
但了个是,但是这个正则还是有问题,由于只允许输入非空白字符,所以你在任何位置输入空白都会导致输入框校验失败
[站外图片上传中…(image-abd68a-1575421399819)]
这里可以使用其余的正则来匹配,比方\^\S+?.+
<form> <label> Input </label> <input type="text" name="input" id="input" required pattern="\S+.*"/></form>现在输入框可以和空格混合输入了!
但是假如当前校验失败,输入框没有任何提醒,这很不友好!
但我写这篇文章的时候,有一个问题我不断思考,能不能只用css给非法验证也加一种样式?
输入无效
这里不能使用:invalid,由于有required字段,即便我们什么也不做,输入框也会有非正确状态的样式提醒,这很奇怪。
查看了相关资源,我们可以使用:placeholder-shown来达到我们的目的
大概思路是:
- 添加placeholder
- 假如输入框假如客户输入了内容,但还不合法做一个解决
- 最后利用css的覆盖特性,增加一个当验证成功的样式解决
最终的css大概是这样
/* 当填充的时候展现红色,所以这里默认是校验失败 */input:not(:placeholder-shown) { border-color: hsl(0, 76%, 50%);}/* 当验证成功的时候,采用这个样式 */input:valid { border-color: hsl(120, 76%, 50%);}这里有一个小小的demo
总结
上面的内容就是如何只用css来提供一个基础表单验证功能,说是只用css,其实也利用的pattern能接受正则表达式,哈哈,所以最根本的是如何写出最优的正则表达式。
原文链接
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » css实现input表单验证