嘿我正在做一个菜单,我希望当我点击该项目进入活动位置,然后当点击另一个项目时,它会更改为最近点击为活动并从最后一个删除状态,这就是我我正在做但是没有工作......如果有人可以帮助我,我感激不尽。
HTML
<div id="nav-pPal">
<ul class="nav-Ppal">
<li><a class="btns-nav" id="0" href="#block-intro">01</a></li>
<li><a class="btns-nav" id="1" href="#block-pq-zolfunza">02</a></li>
<li><a class="btns-nav" id="2" href="#block-modulos-zolfunza">03</a></li>
<li><a class="btns-nav" id="3" href="#block-seguridad">04</a></li>
<li><a class="btns-nav" id="4" href="#block-desarrollo">05</a></li>
<li><a class="btns-nav" id="5" href="#block-nuestra-ubic">06</a></li>
<li><a class="btns-nav" id="6" href="#block-noticias">07</a></li>
<li><a class="btns-nav" id="7" href="#block-preguntas">08</a></li>
<li><a class="btns-nav" id="8" href="#block-contacto">09</a></li>
</ul>
</div>
CSS
.nav-Ppal li a {
width: 30px;
height: 22px;
padding-top:8px;
text-align:center;
display:block;
text-decoration:none;
color:#FFF;
cursor:pointer;
background-color: #000;
color: #FFF;
opacity: 1;
-moz-opacity: 0.70;
-ms-filter:"progid:DXImageTransform.Microsoft.Alpha"(Opacity=70);
cursor:pointer;
font-family: 'lucida_sans_unicoderegular', Helvetica, Arial, sans-serif;
font-size:11px;
}
.nav-Ppal li a:hover {
background-color: #f7941e;
color: #FFF;
display:block;
text-decoration:none;
cursor:pointer;
}
.nav-Ppal-active{
background: white;
color: black;
}
的jQuery
$(".nav-Ppal li a").on("click", checkTarget);
function checkTarget(){
/*$(".nav-Ppal li a").not(this).removeClass(".nav-Ppal_active");*/
$(".nav-Ppal li a").addClass("nav-Ppal-active");
console.log("click");
}
答案 0 :(得分:2)
$(function() {
$(".nav-Ppal li a").on("click", function() {
$(".nav-Ppal li a").removeClass('nav-Ppal-active');
$(this).addClass("nav-Ppal-active");
});
});
这就是你想要做的事情
更改CSS:
.nav-Ppal-active{
background: white;
color: black;
}
默认类会覆盖您的特异性。
答案 1 :(得分:0)
这与使用“hashchange”浏览器事件设置活动元素的solution I recently came up with类似。
以下是您可以使用的jsfiddle example。
使用Javascript:
$(".nav-Ppal li a").on('click', function(e) {
// Hide all content, display the one related to hash-tag
$(".document_view").toggle(false);
$('.nav-Ppal li').removeClass("nav-Ppal-active", false);
});
$(window).on('hashchange', function() {
$("a[href='" + window.location.hash + "']").parent().addClass("nav-Ppal-active", true);
});
此外,将“active”类放在第一个元素上,以便在第一次加载时看起来有效:
<li class="nav-Ppal-active">