带导航的JQuery单页淡入淡出切换

JQuery Single Page Fade In/Out Toggle w/Nav

本文关键字:淡出 淡入 单页 导航 JQuery      更新时间:2023-09-26

Dudes!长期潜伏者。第一项质询。

带有导航菜单的简单页面触发淡入内容div.点击淡入功能,切换目标时淡出!=href("#"(。脚本有效,但这是一个变通办法。这里必须有一个更简单的方法。

JS:

$(document).ready(function(){   
$(".toggle1").click(function(){   
    $('#div1').delay(500).fadeIn('fast');
    $('#div2').fadeOut('slow');
    $('#div3').fadeOut('slow');
});
$(".toggle2").click(function(){   
    $('#div2').delay(500).fadeIn('fast');
    $('#div1').fadeOut('slow');
    $('#div3').fadeOut('slow');
});
$(".toggle3").click(function(){   
    $('#div3').delay(500).fadeIn('fast');
    $('#div1').fadeOut('slow');
    $('#div2').fadeOut('slow');
    });
});

HTML:

    <div class="nav">
        <ul>
            <li><a class="toggle1" href="#div1">div1</a></li>
            <li><a class="toggle2" href="#div2">div2</a></li>
            <li><a class="toggle3" href="#div3">div3</a></li>           
         </ul>
    </div>  

有没有一种方法可以让ONE切换类函数,如果a href==#div,淡入?否则,淡出?

为了清晰起见,我不希望用户在第二次点击同一导航目标时淡出音量切换。只有选择了新目标,当前div才会淡出。

谢谢大家!

在继续动画之前,可以使用以选择器、.filter().stop()if条件开头的属性来检查元素opacity

$().ready(function() {
  $("[class^=toggle]").click(function(e) {
    e.preventDefault();
    var hash = $("#" + this.href.split(/#/).pop());
    if (hash.css("opacity") < 1) {
      $("[id^=div]").stop().fadeTo("fast", 0)
      .filter(hash).delay(500).fadeTo("slow", 1)
    }
  })
})
[id^="div"] {
  opacity: 0;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js">
</script>
<div class="nav">
  <ul>
    <li><a class="toggle1" href="#div1">div1</a>
    </li>
    <li><a class="toggle2" href="#div2">div2</a>
    </li>
    <li><a class="toggle3" href="#div3">div3</a>
    </li>
  </ul>
</div>
<div id="div1">div 1</div>
<div id="div2">div 2</div>
<div id="div3">div 3</div>

这将是我的渐变解决方案。这并不完全是你想要的解决方案,但我相信你可以改变它来做你想做的事情——这个概念就在那里。您还可以在元素上设置.data,以了解该元素是否已褪色。

https://api.jquery.com/jquery.data/

$(document).ready(function(){   
  $(".toggle1").click(function() {
      href = $(this).attr("href");
      if(href.includes("#div")) {
        $('a[href=#div1]').delay(500).fadeIn('fast');
        $('a[href=#div2]').fadeOut('slow');
        $('a[href=#div3]').fadeOut('slow');
      }
  });
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="nav">
        <ul>
            <li><a class="toggle1" href="#div1">div1</a></li>
            <li><a class="toggle2" href="#div2">div2</a></li>
            <li><a class="toggle3" href="#div3">div3</a></li>           
         </ul>
    </div>
<div id="fademe">
testing  
</div>

我的建议是:

$(function () {
  $('[href^="#div"]').click(function () {
    $(this).delay(500).fadeIn('fast');
    var siblings = $(this).parent().siblings();
    $('[href="' + siblings.eq(0).children('a').attr("href") + '"]').fadeOut('slow', function() {
      $('[href="' + siblings.eq(1).children('a').attr("href") + '"]').fadeOut('slow');
    });
  });
  
  $('#btn').on('click', function(e) {
    $('[href^="#div"]').show();
  });
});
<script src="https://code.jquery.com/jquery-1.12.4.min.js"></script>
<div class="nav">
    <ul>
        <li><a class="toggle1" href="#div1">div1</a></li>
        <li><a class="toggle2" href="#div2">div2</a></li>
        <li><a class="toggle3" href="#div3">div3</a></li>
    </ul>
</div>
<button id="btn">Make visible all elements</button>