我正在使用自定义字体(@font-face),除了输入占位符。
字体未显示,占位符为空白。
输入字体(当我键入某种内容时)工作正常。另外,如果我更改系统字体的占位符字体(Arial,Tahoma ...)也可以。
如何为占位符使用自定义字体?
输入:
<input placeholder="Search character" type="text" class="search-character">
CSS:
body { font-family: 'DIN', sans-serif; }
.search-character::-webkit-input-placeholder { /* Chrome/Opera/Safari */
font-family: 'DIN', sans-serif;
}
.search-character::-moz-placeholder { /* Firefox 19+ */
font-family: 'DIN', sans-serif;
}
.search-character:-ms-input-placeholder { /* IE 10+ */
font-family: 'DIN', sans-serif;
}
.search-character:-moz-placeholder { /* Firefox 18- */
font-family: 'DIN', sans-serif;
}
.search-character::placeholder {
font-family: 'DIN', sans-serif;
}
将 font-family
属性应用于 ::placeholder
pseudo-class。
input::placeholder
{
font-family: Helvetica;
}
另外,请注意,input
由于用户代理样式表而默认不继承font-family
;看这个片段:
body
{
font-family: Impact, Haettenschweiler;
}
input::placeholder
{
font-family: Impact, Haettenschweiler;
}
<input type="text" placeholder="hello" />
占位符的样式,但文本不是。
input::placeholder {
font-family: Arial;
}
input:-ms-input-placeholder { /* Internet Explorer 10-11 */
font-family: Arial;
}
input::-ms-input-placeholder { /* Microsoft Edge */
font-family: Arial;
}