我是一个非常基础的编码人员,所以如果我的问题听起来很愚蠢,请多多包涵。我正在使用Bootstrap 3制作某种图库页面,因此顶部有类别过滤器,并且图像行具有响应性(台式机为3幅,平板电脑为2幅,移动设备为1幅)。因此,我目前正在使用灯箱插件,这样,当用户单击缩略图时,它将显示一个灯箱。因此,这是HTML中的代码:
<div class="container">
<div class="row">
<div align="center" class="filter-categories">
<button class="btn btn-default filter-button" data-filter="all">all</button>
<button class="btn btn-default filter-button" data-filter="fine-art">fine art</button>
<button class="btn btn-default filter-button" data-filter="actor-portraits">portraits</button>
<button class="btn btn-default filter-button" data-filter="landscape">landscape</button>
<button class="btn btn-default filter-button" data-filter="street">street</button>
</div>
</div>
<br/>
<div class="row" align="center">
<!-- fine art-->
<div class="gallery_product filter fine-art col-md-4 col-sm-6 col-xs-12">
<a href="images/fine art photography/image-1.jpg" data-lightbox="gallery" data-image-alt="Image 1"> <img src="images/fine art photography/image-1.jpg" alt="Alt Text" class="gallery-image" />
<div class="overlay">
<div class="text">Hello World</div>
</div>
</a> </div>
...
,因此,当单击<!-- fine art-->
时,它会显示为一个灯箱,并且会出现箭头导航到下一张图像。对于overlay
,将鼠标悬停在图片缩略图上方时,应该会显示一个带有text
的黑框,但是对于col-md-4 col-sm-6 col-xs-12
,它在左侧和右侧的距离要多出15像素奇怪的原因。下面是本节的CSS
/*hover effect*/
/*.gallery_product.col-md-4.col-sm-6.col-xs-12{
padding: 0 !important;
}*/
.gallery_product {
position: relative;
top:0;
left: 0;
}
.gallery-image {
display: block;
width: 100%;
height: auto;
}
.gallery_product {
margin-bottom: 30px;}
.overlay {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
height: 100%;
width: 100%;
opacity: 0;
transition: .5s ease;
background-color: #121212;
}
.gallery_product:hover .overlay {
opacity: 1;
}
.text {
color: white;
font-size: 20px;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
text-align: center;
}
padding: 0 !important
,只会删除磁贴之间的空间。我仍然想在图块之间保留空间,但要在图块内保留覆盖。我尝试过:
<!-- fine art-->
<div class="col-md-4 col-sm-6 col-xs-12">
<div class="gallery_product filter fine-art">
<a href="images/fine art photography/image-1.jpg" data-lightbox="gallery" data-image-alt="Image 1"> <img src="images/fine art photography/image-1.jpg" alt="Alt Text" class="gallery-image" />
<div class="overlay">
<div class="text">Hello World</div>
</div>
</a> </div></div>
它提供了我想要的内容,但是我的data-lightbox
无法正常工作,下一个和上一个按钮被禁用。因此从本质上讲,我需要第一个代码,但要删除overlay
div的多余部分。有人能帮忙吗?非常感谢!!
答案 0 :(得分:0)
这是最短的解决方案。
更改此:
.overlay {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
height: 100%;
width: 100%;
opacity: 0;
transition: .5s ease;
background-color: #121212;
}
对此:
.overlay {
position: absolute;
top: 0;
bottom: 0;
left: 15px;
right: 15px;
/* height: 100% */;
/* width: 100% */;
opacity: 0;
transition: .5s ease;
background-color: #121212;
}