繁体   English   中英

如何在图像上应用悬停效果?

[英]How to apply hover effect on images?

我使用了spotlight包并对其进行了自定义,我想要div中的hover效果,当我悬停它时,会出现search按钮,当我移除光标时,按钮会消失。

为此,我在addEventListener中使用mouseovermouseout事件。

html:

<div class="container">
    <div class="row">
        <div class="col-md-4 column-container">

            <a href="https://www.google.com">

                <img src="demo/gallery/brooklyn-bridge-1791001-thumb.jpg" alt="">

            </a>

            <button type='button' onclick="showGallery(1)" class="main-search-btn" data-bs-toggle="tooltip"
                data-bs-placement="bottom" title="bottom">
                <i class="fa fa-search" aria-hidden="true"></i>

            </button>


        </div>
        <div class="col-md-4 column-container">

            <a href="https://www.google.com">


                <img class="img-fluid" src="https://source.unsplash.com/random" alt="">

            </a>

            <button type='button' onclick="showGallery(4)" class="main-search-btn" data-bs-toggle="tooltip"
                data-bs-placement="bottom" title="bottom">
                <i class="fa fa-search" aria-hidden="true"></i>

            </button>


        </div>



    </div>
</div>

以下是我用来通过loop为每个元素构建此逻辑的js代码。

document.querySelectorAll(".column-container").forEach((item, index) => {
  console.log(item);
  search = document.querySelectorAll(".main-search-btn")[index];
  console.log(search);

  item.addEventListener("mouseover", () => {
    search.style.display = "initial";
  });
});
document.querySelectorAll(".column-container").forEach((item, index) => {
  search = document.querySelectorAll(".main-search-btn")[index];
  console.log(search);

  item.addEventListener("mouseout", () => {
    search.style.display = "none";
  });
});

问题是上面的js代码仅适用于最后一个 div 元素,而不是将此悬停效果应用于所有元素。

样式.css

.fa-search {
  color: white !important;
}
div.column-container {
  position: relative;
  /* border: 2px solid blue; */
}
div.column-container a img {
  width: 100% !important;
  border: 2px solid blue;
}

.main-search-btn {
  /* border: 2px solid blue; */
  display: none;
  background-color: #000 !important;
  top: -3px;
  right: 10px;
  border-radius: 0px;
  z-index: 10000;
  position: absolute;
}

那么,如何通过循环为所有div元素运行它?

您可以尝试使用css来实现相同的结果,而不是使用javascript使事情变得复杂。 我举了一个例子,用简单的一行 css 你可以做超过 18 行 javascript 代码的事情

.column-container:hover .main-search-button {
    display: initial;
}

不需要任何 js 的纯 css 应该可以达到预期的结果。

.fa-search {
  color: white !important;
}
div.column-container {
  position: relative;
  /* border: 2px solid blue; */
}
div.column-container a img {
  width: 100% !important;
  border: 2px solid blue;
}

.main-search-btn {
  /* border: 2px solid blue; */
  background-color: #000 !important;
  top: -3px;
  right: 10px;
  border-radius: 0px;
  z-index: 10000;
  position: absolute;
}

div.column-container .main-search-btn {
  display: none;
}

div.column-container:hover .main-search-btn {
  display: initial;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM