感谢下面的所有帮助,解决方案。
我是网络开发的新手,我正在尝试重建一个网站来练习我的CSS。
问题中的网站是http://www.divecarib.com。如果向下滚动到该主页上的图片,您会注意到它们在悬停时“淡化”。我如何实现这种淡化?使用不透明度可以使背景图像通过,而不是在该网站上实现的方式。
感谢您的帮助!
以下是我的淡入淡出尝试...不包括原始帖子中的代码,因为我认为这是无关紧要的,因为我走错了路。
.fade {
opacity: 1;
transition: opacity .25s ease-in-out;
-moz-transition: opacity .25s ease-in-out;
-webkit-transition: opacity .25s ease-in-out;
}
.fade:hover {
opacity: 0.7;
}
---解决方案(至少我是如何做到的 - 取自http://jsbin.com/igahay/1/edit?html,output)-----
<div class=picSet>
<figure class="tint">
<p id="#p1">Student in training</p>
<p id="#p2" style="position: absolute;top: 36px; color: white;">SKAT crew doing open water training</p>
<img id=pic1 src="Media/pic1.jpg" />
</figure>
</div>
.tint {
position: relative;
float: left;
margin: 3px;
cursor: pointer;
}
.tint:before {
content: "";
display: block;
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
}
.tint:hover:before {
content: "";
background: rgba(96,150,179, 0.54);
border: 5px solid #0B689A;
border-radius: 20px;
margin: 3px;
}
.tint p{
position:absolute;
top:20px;
left:20px;
margin: 0;
padding: 0;
font-family: sans-serif;
font-size: 0.75em;
display: none;
color: #0B689A;
}
.tint:hover > p{
display: block;
}
答案 0 :(得分:7)
你不能淡化元素的不透明度,而不会让后面的东西显示出来。
您链接的网站并未淡化图像的不透明度,但在顶部引入半透明图层并显示文字。
如果您只想淡化图像,但没有透过背景,可以在图像周围放置一个带有纯色背景的包装。但是,没有办法淡化图像,也没有显示出来的东西。
.container {
background:#FFF;
}
.container img:hover {
opacity:0.8;
}