我试图在输入字段上使用:after CSS伪元素,但它不起作用。如果我将其与跨度一起使用,它可以正常工作。

<style type="text/css">
.mystyle:after {content:url(smiley.gif);}
.mystyle {color:red;}
</style>

这是有效的(将笑脸放在“buu!”之后,然后放在“somemore”之前)

<span class="mystyle">buuu!</span>a some more

这不起作用-它只将someValue涂成红色,但没有笑脸。

<input class="mystyle" type="text" value="someValue">

我做错了什么?我应该使用另一个伪选择器吗?

注意:我不能在输入周围添加跨度,因为它是由第三方控件生成的。


当前回答

前后切换开关示例只需将输入包装在div块上

.fm表单控件{位置:相对;页边空白:25px;边距底部:25.2px;}.fm切换器{显示:无;}.fm切换开关:选中+.fm占位符切换开关:在之后{背景色:#94c6e7;}.fm切换器:已选中+.fm占位符切换器{左:24px;}.fm切换器[已禁用]+.fm占位符切换器{游标:不允许;}.fm切换器[已禁用]+.fm占位符切换器:之前{背景色:#cbd0d3;}.fm切换器[已禁用]+.fm占位符切换器:之后{背景色:#eaeeded;边框颜色:#cbd0d3;}.fm占位符切换器{左填充:53px;光标:指针;线条高度:24px;}.fm占位符切换器:之前{位置:绝对;内容:“”;左:0;顶部:50%;宽度:20px;高度:20px;页边空白:-10px;左边距:2px;背景色:#2980b9;z指数:2;-moz转换:所有0.15s都易于进出;-o型转换:所有0.15s都易于进出;-webkit转换:所有0.15s都易于输入输出;过渡:所有0.15s均缓进缓出;边框半径:12px;}.fm占位符切换器:在之后{位置:绝对;内容:“”;左:0;顶部:50%;宽度:48px;高度:20px;页边空白:-12px;背景色:#ffffff;z指数:1;边框半径:12px;边框:2px实心#bdc3c7;-moz转换:所有0.15s都易于进出;-o型转换:所有0.15s都易于进出;-webkit转换:所有0.15s都易于输入输出;过渡:所有0.15s均缓进缓出;}<div class='fm表单控件'><input class=‘m-switcher‘id=‘switcher_id‘type=‘checkbox‘><label class='m-placeholder-switcher'for='switcher_id'>切换器</label></div>

其他回答

尽管有解释指出Firefox不允许::after和::before内容用于无法显示任何内容的元素的行为是正确的,但这一规则似乎仍然适用:

input[type=checkbox] {
    -moz-appearance: initial;
}

由于::after是重新设置复选框或单选框样式的唯一方法,而不会引入更多无关的标记,如尾随跨度或标签,我认为可以强制Firefox允许显示::before和::aft内容,尽管不符合规范。

如果您试图使用:before和:after来设置输入元素的样式,那么很可能您试图模仿CSS堆栈中其他span、div甚至某个元素的效果。

正如Robert Koritnik的回答所指出的,:before和:after只能应用于容器元素,而输入元素不是容器。

然而,HTML5引入了button元素,它是一个容器,其行为类似于input[type=“submit | reset”]元素。

    <style>
    .happy:after { content:url(smiley.gif); }
    </style>

    <form>
    <!-- won't work -->
    <input class="happy" type="submit" value="Submit" />

    <!-- works -->
    <button class="happy">Submit</button>
    </form>

问题提到“输入字段”。虽然我相信OP引用的是type=text、::after和::before的输入字段,但伪内容确实呈现了几种不同类型的输入字段:

input::before {
    content: "My content" /* 11 different input types will render this */
}    

这里是所有输入类型的全面演示,清楚地显示了哪些类型与(在本例中)::before伪元素兼容。

总之,这是可以呈现伪内容的所有输入类型的列表:

复选框颜色日期本地日期时间文件形象月无线电广播范围时间周

您不能在输入元素中放置伪元素,但可以放置阴影元素,如占位符!

input[type="text"] {   
  &::-webkit-input-placeholder {
    &:before {
      // your code
    }
  }
}

要使其在其他浏览器中工作,请在不同的选择器中使用:-moz占位符、::-moz placeholder和:-ms input placeholder。无法对选择器进行分组,因为如果浏览器无法识别选择器,则整个语句将无效。

更新:以上代码仅适用于CSS预处理器(SASS、LESS…),不使用预处理器:

input[type="text"]::-webkit-input-placeholder:before { // your code }

伪元素如:after、:before仅用于容器元素。在单个位置开始和结束的元素,如<input/>、<img>等,都不是容器元素,因此不支持伪元素。一旦将伪元素应用于容器元素(如<div>),如果检查代码(参见图片),就可以理解我的意思。实际上,伪元素是在容器元素内部创建的。这在<input>或<img>的情况下是不可能的