是否有一种方法来检测输入是否有文本在它通过CSS?我尝试过使用:empty伪类,也尝试过使用[value=""],这两种方法都不起作用。我似乎找不到一个单一的解决方案。
我想这一定是可能的,考虑到我们有:checked和:indeterminate的伪类,两者都是类似的东西。
请注意:我这样做是为了“时尚”风格,它不能利用JavaScript。
还要注意,在客户端,在用户无法控制的页面上使用了Stylish。
是否有一种方法来检测输入是否有文本在它通过CSS?我尝试过使用:empty伪类,也尝试过使用[value=""],这两种方法都不起作用。我似乎找不到一个单一的解决方案。
我想这一定是可能的,考虑到我们有:checked和:indeterminate的伪类,两者都是类似的东西。
请注意:我这样做是为了“时尚”风格,它不能利用JavaScript。
还要注意,在客户端,在用户无法控制的页面上使用了Stylish。
当前回答
实际上有一种不需要JavaScript的方法。
如果你将<input>的required选择器设置为true,你可以用CSS:valid标签检查其中是否有文本。
引用:
MDN文档 CSS技巧
输入{ 背景:红色; } 输入:有效的{ 背景:lightgreen; } <input type="text" required>
其他回答
在HTML部分这样做:
<input type="text" name="Example" placeholder="Example" required/>
为了有效,必需的参数将要求它在输入字段中有文本。
实际上有一种不需要JavaScript的方法。
如果你将<input>的required选择器设置为true,你可以用CSS:valid标签检查其中是否有文本。
引用:
MDN文档 CSS技巧
输入{ 背景:红色; } 输入:有效的{ 背景:lightgreen; } <input type="text" required>
这在css中是不可能的。要实现这一点,你必须使用JavaScript(例如$("#input").val() == "")。
简单的css:
input[value]:not([value=""])
如果输入被填满,这段代码将在页面加载上应用给定的css。
基本上每个人都在寻找的是:
少:
input:focus:required{
&:invalid{ color: red; border-color: red; box-shadow: 0 0 6px red;}
&:valid,
&:placeholder-shown{ border-color: green; box-shadow: 0 0 8px green;}
}
纯CSS:
input:focus:required:invalid{ color: red; border-color: red; box-shadow: 0 0 6px red;}
input:focus:required:valid,
input:focus:required:placeholder-shown{ border-color: green; box-shadow: 0 0 8px green;}