是否有一种方法来检测输入是否有文本在它通过CSS?我尝试过使用:empty伪类,也尝试过使用[value=""],这两种方法都不起作用。我似乎找不到一个单一的解决方案。
我想这一定是可能的,考虑到我们有:checked和:indeterminate的伪类,两者都是类似的东西。
请注意:我这样做是为了“时尚”风格,它不能利用JavaScript。
还要注意,在客户端,在用户无法控制的页面上使用了Stylish。
是否有一种方法来检测输入是否有文本在它通过CSS?我尝试过使用:empty伪类,也尝试过使用[value=""],这两种方法都不起作用。我似乎找不到一个单一的解决方案。
我想这一定是可能的,考虑到我们有:checked和:indeterminate的伪类,两者都是类似的东西。
请注意:我这样做是为了“时尚”风格,它不能利用JavaScript。
还要注意,在客户端,在用户无法控制的页面上使用了Stylish。
当前回答
您可以利用占位符并使用:
input:not(:placeholder-shown) {
border: 1px solid red;
}
其他回答
你可以使用上面写的没有必填字段的占位符技巧。
required的问题是,当你写了一些东西,然后删除它——作为HTML5规范的一部分,输入现在总是红色的——然后你就需要一个上面写的CSS来修复/覆盖它。
你可以简单地做w/o要求的事情
<input type="text" placeholder="filter here" id="mytest" />
CSS
#mytest:placeholder-shown {
/* if placeholder is shown - meaning - no value in input */
border: black 1px solid;
color: black;
}
#mytest {
/* placeholder isn't shown - we have a value in input */
border: red 1px solid;
color: red;
}
代码笔:https://codepen.io/arlevi/pen/LBgXjZ
您可以利用占位符并使用:
input:not(:placeholder-shown) {
border: 1px solid red;
}
这在css中是不可能的。要实现这一点,你必须使用JavaScript(例如$("#input").val() == "")。
您可以使用:占位符显示的伪类。从技术上讲,占位符是必需的,但您可以使用空格代替。
输入:没有(placeholder-shown) { 边框颜色:绿色; } 输入:placeholder-shown { 边框颜色:红色; } <input placeholder="Text is required" /> <input placeholder=" " value="This one is valid" /> <input placeholder=" " /> .
实际上有一种不需要JavaScript的方法。
如果你将<input>的required选择器设置为true,你可以用CSS:valid标签检查其中是否有文本。
引用:
MDN文档 CSS技巧
输入{ 背景:红色; } 输入:有效的{ 背景:lightgreen; } <input type="text" required>