单页动态内容替换站点 - 如何单独突出显示当前内容链接



我有一个页面站点,当我单击菜单时,内容将通过jQuery替换。尽管这些项目没有链接到不同的页面,但只有不同的divs,但我想让菜单像常规网站菜单一样具有3种活动状态:不活动,悬停和"当前内容"(如当前/活动页面,但它赢了't实际上链接到另一页)。

我希望每个单独的链接在单击"当前内容"状态时匹配它的悬停颜色。(现在我只有一个jQuery件,它会使任何"当前"链接红色...我希望更多控制权)我希望这有意义...代码下面!

html

<div id="sidebar">
    <nav>
    <ul id="nav">
        <li id="home"><a id="showdiv1">Home</a></li>
        <li id="about"><a id="showdiv2">About</a></li>
        <li id="demoReel"><a id="showdiv3">Demo Reel</a></li>
        <li id="contact"><a id="showdiv4">Contact</a></li>
    </ul><!-- /#nav -->
    </nav>
</div><!-- /#sidebar -->
<div id="content">
        <div id="div1">Blah blah!</div>
        <div id="div2" style="display:none;">Blardy blah!</div>
        <div id="div3" style="display:none;">Moo!</div>
        <div id="div4" style="display:none;">Shmeee!</div>
</div><!-- /#content -->

CSS

#sidebar {
float:right;
width:30%;
}
    ul#nav li#home a:hover { color:red;}
    ul#nav li#about a:hover { color:green; }
    ul#nav li#demoReel a:hover { color:blue; }
    ul#nav li#contact a:hover { color:yellow; }
    .active a { color:red; }
#content {
    float:left;
    width:60%;
}

jQuery

$(function() {
//Highlight active navigation link
$("ul").delegate("li", "click", function() {
    $(this).addClass("active").siblings().removeClass("active");
});

//Fade-in/hide selected navigation link
$('#showdiv1').click(function() {
    $('div[id^=div]').hide();
    $('#div1').fadeIn();
});
$('#showdiv2').click(function() {
    $('div[id^=div]').hide();
    $('#div2').fadeIn();
});
$('#showdiv3').click(function() {
    $('div[id^=div]').hide();
    $('#div3').fadeIn();
});
$('#showdiv4').click(function() {
    $('div[id^=div]').hide();
    $('#div4').fadeIn();
});
})

我想指出,我对这些东西非常陌生,并且完全是自学的,所以请原谅错误。更重要的是,非常感谢您的帮助!

而不是

.active a { color:red; }

尝试更换

ul#nav li#home a:hover { color:red;}
ul#nav li#about a:hover { color:green; }
ul#nav li#demoReel a:hover { color:blue; }
ul#nav li#contact a:hover { color:yellow; }

ul#nav li#home a:hover, ul#nav li#home.active a { color:red;}
ul#nav li#about a:hover, ul#nav li#about.active a { color:green; }
ul#nav li#demoReel a:hover, ul#nav li#demoReel.active a { color:blue; }
ul#nav li#contact a:hover, ul#nav li#contact.active a { color:yellow; }

以这种方式,每个链接在悬停时会获得特殊的颜色,当它的父行为为"活动"。

相关内容

  • 没有找到相关文章

最新更新