javascript - jQuery 在悬停时显示/隐藏 div(多个实例)

标签 javascript jquery html css

我有 6 个缩略图,其中一个单独的 div 中有 6 个隐藏标题。我想在悬停时显示相应的标题,并在推出时再次隐藏它。

目前,我已经设法使用 .hide();.show(); 方法使其工作,但如果用户滚动了任何在页面完全加载之前,缩略图的缩略图堆叠在一起,并且似乎无法正确切换可见性。

编辑 - 这是 fiddle我把它放在一起,显示了它的实际作用,但是我似乎无法复制这里看到的问题 http://2xdare.co/projects/ (尝试将鼠标悬停在缩略图上时刷新)

我认为这与我如何调用与 DOM 相关的脚本有关 - 但我不确定我做错了什么(我对 jQuery 和 Javascript 的了解非常有限)

缩略图:

<a class="imagelink post1" href=""><div class="thumb"></div></a>

标题:

<div class="caption-container">
    <div class="projectcaptions hide-mobile">
      <div class="surgedesc">
        <h3>Title</h3>
        <p class="fields">Field captions</p>
        <p class="captions">Captions</p>
      </div>
    </div>
<div>

jQuery:

jQuery(document).ready(function($) {


//  Mobile Nav
jQuery(function($){
         $( '#nav-toggle' ).click(function(){
             $('.responsive-menu').toggleClass('expand')
             $('.main-header').toggleClass('blackout')
         })
    });
//  Coverfade element
$(window).scroll(function(i){
    var scrollVar = $(window).scrollTop();
    $('.coverelement, #arrow').css({
        'opacity':( 300-$(window).scrollTop() )/300
    });
});

//  CAPTION ROLLOVER
$(window).load(function(){
    var cancel = false;
    $("div.surgedesc").hide();
    $(".post1").hover(function(){
        cancel = (cancel)?false: true;    
        if(!cancel){
        $("div.surgedesc").hide();
        }
        else if(cancel){
        $("div.surgedesc").show();
        }    
    });
    var cancel = false;
    $("div.linierdesc").hide();
    $(".post2").hover(function(){
        cancel = (cancel)?false: true;    
        if(!cancel){
        $("div.linierdesc").hide();
        }
        else if(cancel){
        $("div.linierdesc").show();
        }    
    });
    var cancel = false;
    $("div.we-are-foreverdesc").hide();
    $(".post3").hover(function(){
        cancel = (cancel)?false: true;    
        if(!cancel){
        $("div.we-are-foreverdesc").hide();
        }
        else if(cancel){
        $("div.we-are-foreverdesc").show();
        }    
    });
    var cancel = false;
    $("div.worth-popupdesc").hide();
    $(".post4").hover(function(){
        cancel = (cancel)?false: true;    
        if(!cancel){
        $("div.worth-popupdesc").hide();
        }
        else if(cancel){
        $("div.worth-popupdesc").show();
        }    
    });
    var cancel = false;
    $("div.walk-the-linedesc").hide();
    $(".post5").hover(function(){
        cancel = (cancel)?false: true;    
        if(!cancel){
        $("div.walk-the-linedesc").hide();
        }
        else if(cancel){
        $("div.walk-the-linedesc").show();
        }    
    });
    var cancel = false;
    $("div.the-looking-glassdesc").hide();
    $(".post6").hover(function(){
        cancel = (cancel)?false: true;    
        if(!cancel){
        $("div.the-looking-glassdesc").hide();
        }
        else if(cancel){
        $("div.the-looking-glassdesc").show();
        }    
    });


}); 
}); 

非常感谢!

最佳答案

您的cancel变量对于每个悬停事件来说并不是唯一的,因为它看起来是意图。相反,它是所有 6 个部分共享的单个变量。

您有权访问 DOM 标记吗?我发现在 HTML 本身中定义自定义属性并让 JS 在需要时使用该值更易于维护:

<div class="caption-container">
    <div class="projectcaptions hide-mobile">
      <div data-showonhover=".post1">...</div>
      <div data-showonhover=".post2">...</div>
      <div data-showonhover=".post3">...</div>
      <div data-showonhover=".post4">...</div>
    </div>
<div>

然后您可以使用此自定义属性找到任何元素,并在悬停时toggle()目标:

$("[data-showonhover]").hover(function(){
    $($(this).data("showonhover")).toggle();
});

关于javascript - jQuery 在悬停时显示/隐藏 div(多个实例),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29759760/

相关文章:

html - 图像在 div 元素边界之外不可见

javascript - 如何解决 "slider' s all images display "in Angularjs But in HTML slider works correctly

java - 将 Javascript 中的字符串发送到 Play Framework 中的 java 方法

javascript - 如何从浏览器历史记录中完全隐藏网站?

c# - RedirectToAction 在页面中显示 404,但仍会重定向

javascript - 有问题的 jQuery 滚动代码

javascript - 可以访问 Stackoverflow 的自动建议标记系统吗?

javascript循环迭代太多

javascript - Grails 如何在 javascript 中获取用户名?

javascript - 如何创建可与背景渐变和重叠透明形状配合使用的嵌入曲线背景?