将鼠标悬停在元素上动画化下一个元素-如何删除内联JS

Hover over element animate next element - How to remove inline JS

本文关键字:元素 何删除 删除 JS 悬停 鼠标 动画 下一个      更新时间:2023-09-26

我对JavaScript相对陌生,但我正在努力寻找一种更有效的方法来调用滚动函数,而不在HTML中使用内联事件。以下是我目前使用的方法:

HTML

        <div id="work_square">
        <img onmouseover="rolloverIn('rollover_1');" onmouseout="rolloverOut('rollover_1');" src="images/frugal_image.png" width="100%"/>
        <div onmouseover="rolloverIn('rollover_1');" onmouseout="rolloverOut('rollover_1');" id="rollover_1" class="rollovers">
            <div id="rollover_text">
                <h2>ROLLOVER 1 TITLE</h2>
                <p>This is rollover 1.</p>
            </div>
        </div>
    </div>
    <div id="work_square">
        <img onmouseover="rolloverIn('rollover_2');" onmouseout="rolloverOut('rollover_2');" src="images/exhibiton_image.jpg" width="100%"/>
        <div onmouseover="rolloverIn('rollover_2');" onmouseout="rolloverOut('rollover_2');" id="rollover_2" class="rollovers">
            <div id="rollover_text">
                <h2>ROLLOVER 2 TITLE</h2>
                <p>This is rollover 2.</p>
            </div>
        </div>
    </div>

JS-

<script>
function rolloverIn(el){
    var elem = document.getElementById(el);
    elem.style.opacity = 1;
    elem.style.transform = "scale(1)";
}
function rolloverOut(el){
    var elem = document.getElementById(el);
    elem.style.opacity = 0;
    elem.style.transform = "scale(0)";
}

基本上,我调用的是一个函数,当鼠标悬停在图像或鼠标悬停时,为放置在每个work_square上的鼠标悬停应用CSS转换和不透明度更改,然后在鼠标悬停时删除更改。

这种方法有效,但据我所知,内联编码是一种糟糕的做法。有人能为我指明一个更有效的方法的正确方向吗?

谢谢。

很抱歉破坏了你使用JS的梦想,但
这在纯CSS中都是可行的

.work_square{ position:relative; }
.work_square > img{ width:100%; }
.work_square .rollovers{
  position:absolute;
  top:0;
  opacity:0;
  transform: scale(0);
  transition: 0.6s;
}
.work_square:hover .rollovers{
  transform: scale(1);
  opacity:1;
}
    <div class="work_square">
      <img src="//placehold.it/800x300/cf5" />
      <div class="rollovers">
        <div class="rollover_text">
          <h2>ROLLOVER 1 TITLE</h2>
          <p>This is rollover 1.</p>
        </div>
      </div>
    </div>
    <div class="work_square">
      <img src="//placehold.it/800x300/f5f" />
      <div class="rollovers">
        <div class="rollover_text">
          <h2>ROLLOVER 2 TITLE</h2>
          <p>This is rollover 2.</p>
        </div>
      </div>
    </div> 

请注意,我已经删除了所有不必要的ID(嘿,在有效的HTML文档中不能使用重复的ID)
使用容器类.work_square并使用其上的CSS :hover来添加侦听器,而不是简单地将子元素的所需类添加到目标:

.work_square:hover .rollovers{

首先,永远不要对多个元素使用相同的ID,ID是唯一的。你想要的是类,所以你的HTML代码应该改成这样:

<div class="work_square">
    <img class="rollover" src="images/frugal_image.png" width="100%"/>
    <div class="rollover">
        <div class="rollover_text">
            <h2>ROLLOVER 1 TITLE</h2>
            <p>This is rollover 1.</p>
        </div>
    </div>
</div>
<div class="work_square">
    <img class="rollover" src="images/exhibiton_image.jpg" width="100%"/>
    <div class="rollover">
        <div class="rollover_text">
            <h2>ROLLOVER 2 TITLE</h2>
            <p>This is rollover 2.</p>
        </div>
    </div>
</div>

现在,如果您想使用纯JavaScript,而不需要内联代码,您可以轻松地使用rollover类来选择所有元素,并将mouseovermouseout事件绑定到您的函数。这是正确的代码:

function rolloverIn(e){
    this.style.opacity = 1;
    this.style.transform = "scale(1)";
}
function rolloverOut(e){
    this.style.opacity = 0;
    this.style.transform = "scale(0)";
}
var elements = document.getElementsByClassName('rollover');
for (var i=0; i < elements.length; i++) {
    elements[i].addEventListener('mouseover', rolloverIn);
    elements[i].addEventListener('mouseout', rolloverOut);
}