引导程序:悬停叠加层(通过CSS)大于图像

时间:2018-07-22 18:59:33

标签: javascript jquery html css twitter-bootstrap-3

我是一个非常基础的编码人员,所以如果我的问题听起来很愚蠢,请多多包涵。我正在使用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的多余部分。有人能帮忙吗?非常感谢!!

1 个答案:

答案 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;
}