是否有一个CSS属性可以反转font-color
,具体取决于background-color
这样的图片?
答案 0 :(得分:67)
有一个名为mix-blend-mode的CSS属性,但IE不支持它。我建议使用pseudo elements。如果你想支持IE6和IE7,你也可以使用two DIVs而不是伪元素。
.inverted-bar {
position: relative;
}
.inverted-bar:before,
.inverted-bar:after {
padding: 10px 0;
text-indent: 10px;
position: absolute;
white-space: nowrap;
overflow: hidden;
content: attr(data-content);
}
.inverted-bar:before {
background-color: aqua;
color: red;
width: 100%;
}
.inverted-bar:after {
background-color: red;
color: aqua;
width: 20%;
}
<div class="inverted-bar" data-content="Lorem ipsum dolor sit amet"></div>
答案 1 :(得分:48)
是的,现在有了。使用mix-blend-mode
,可以使用CSS完成。
div {
position:absolute;
height:200px
}
/* A white bottom layer */
#whitebg {
background: white;
width:400px;
z-index:1
}
/* A black layer on top of the white bottom layer */
#blackbg {
background: black;
width:100px;
z-index:2
}
/* Some white text on top with blend-mode set to 'difference' */
span {
position:absolute;
font-family: Arial, Helvetica;
font-size: 100px;
mix-blend-mode: difference;
color: white;
z-index: 3
}
/* A red DIV over the scene with the blend-mode set to 'screen' */
#makered {
background-color: red;
mix-blend-mode: screen;
width:400px;
z-index:4
}
&#13;
<div id="whitebg"></div>
<div id="blackbg"></div>
<div id="makered"></div>
<span>test</span>
&#13;
目前,这是最前沿的并且并未得到所有浏览器的广泛支持 - 但有一天它可能是标准的。您可能需要启用混合模式功能才能使其正常工作。
答案 2 :(得分:2)
我知道这是一个古老的问题,但是我想添加一个我在了解mix-blend-mode
之前一直使用的解决方案。
该想法是使信息分为两层,即背景和前景,其中背景和前景具有不同的背景和文本颜色。这些在尺寸和文字上都是相同的。在这两者之间,我使用裁剪框div
将顶层裁剪为所需的宽度,显示未裁剪的顶层,并在裁剪窗口之外显示背景层。
这类似于接受的答案中的“ Two div”解决方案,但是使用了额外的裁剪框。如果需要,它可以使文本容易居中,并且可以直接简单地选择颜色。
HTML:
<div class='progress' id='background'>
<span></span>
<div class='progress' id='boundbox'>
<div class='progress' id='foreground'>
</div>
</div>
</div>
CSS(对于令人困惑的ID名称“ background”和“ foreground”,我深表歉意):
.progress {
display: block;
margin: 0;
/* Choose desired padding/height in coordination with font size */
padding: 10px;
height: 28px;
}
#background {
position: relative;
/* Choose a border to your liking, or none */
border: 1px solid lightgray;
/* Choose your desired text attributes */
text-align: center;
font-family: Calibri, "Sans Serif";
font-size: 16pt;
/* Set the desired width of the whole progress bar */
width: 75%;
/* Choose the desired background and text color */
background-color: white;
color: black;
}
#foreground {
position: absolute;
left: 0;
top: 0;
/* Choose the desired background and text colors */
background-color: navy;
color: white;
}
#boundbox {
position: absolute;
left: 0;
top: 0;
overflow: hidden;
}
我使用jQuery以编程方式设置进度百分比,并确保前景的宽度与背景的宽度匹配,并且确保它们具有相同的文本。使用纯Javascript也可以轻松完成此操作。
// Set foreground width to background width
// Do this after DOM is ready
$('#foreground').width($('#background').width())
// Based upon an event that determines a content change
// you can set the text as in the below example
percent_complete = 45 /* Compute a % complete value */
$('#foreground').text(`${percent_complete}% complete`)
$('#background span').text($('#foreground').text())
$('#boundbox').css('width', `${percent_complete}%`)
这是一个小提琴:Progress bar。
我在Chrome,Firefox和Microsoft Edge中对此进行了测试。
答案 3 :(得分:-1)
我认为这更容易理解。
*{
margin: 0;
padding: 0;
box-sizing: border-box;
font-family: sans-serif;
}
.titulo{
text-align: center;
margin: 2em;
}
.padre{
margin: 0 auto;
display: flex;
justify-content: center;
align-items: center;
margin-top: 10em;
position: relative;
width: 1000px;
height: 500px;
}
.caja-1{
background-color: black;
width: 500px;
height: 500px;
left: 0;
mix-blend-mode: screen;
position:absolute;
}
.caja-3{
width: 500px;
height: 500px;
display: flex;
background-color: white;
position: absolute;
right: 0;
}
.texto{
font-size: 5em;
color: white;
mix-blend-mode: difference;
position:absolute;
}
<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>ESTILOS CONTRASTADOS CSS3</title>
</head>
<body>
<h1 class="titulo">MIX-BLEND-MODE CSS EFFECT</h1>
<div class="padre">
<div class="caja-1"></div>
<div class="caja-3"></div>
<h1 class="texto">CODE STOCK CENTER</h1>
</div>
</body>
</html>