我需要帮助来帮助编辑以下JavaScript。
<script>
$('.nav li a').on('click', function() {
$(this).parent().parent().find('.active').removeClass('active');
$(this).parent().addClass('active');
});
</script>
=============================================== ====================
除了现有的功能外,单击“link1”时,我需要“link2”变为“活动”。请参阅下面的HTML。
<h1 class="brand"><a href="#link1">Brand</a></h1>
<ul class="nav">
<li class="active"><a href="link2">One</a></li>
<li><a href="link3">Two</a></li>
<li><a href="link4">Three</a></li>
</ul>
答案 0 :(得分:0)
假设你应该在页面上只有一个活动元素,你可以这样做。
$('.nav li a').on('click', function() {
$('.active').removeClass('active');
$(this).parent().addClass('active');
});
如果没有,那么你可以像closest
这样使用
$('.nav li a').on('click', function() {
$(this).closest('.active').removeClass('active');
$(this).parent().addClass('active');
});
从您的评论中我认为这可能有效
$('.nav li a').on('click', function() {
$('active').removeClass('active');
var link = $(this).attr('href'), // link1
number = parseInt(link.substr(-1)), // 1
newHref = link.slice(0, link.length - 1) + number++;
$(newHref).addClass('active');
});
因此,如果您点击link1
,那么link2
将获得有效课程,然后点击link2
,然后link3
将获得它等等....
答案 1 :(得分:0)
您可以使用以下代码。这里有一个jsFiddle样本。
$('.nav li a').on('click', function (event) {
event.preventDefault(); //Add this only if you want to stop the default link action.
$(this).parent().siblings('li').removeClass('active');
$(this).parent().addClass('active');
});
//The below is to make #link2 active whenever #link1 is clicked.
$('.brand a').on('click', function () {
$('.nav li:first').addClass('active');
$('.nav li:first').siblings('li').removeClass('active');
});