У меня есть веб-сайт с прокруткой страниц и вы хотите изменить активный класс моих ссылок как по прокрутке, так и по щелчку. Я нашел некоторые большие фрагменты этого сайта, которые делают половину работы (для тех, кто заинтересован в этом также делает плавный скроллинг):Изменение активного пункта меню на прокрутке с несколькими меню
$(document).ready(function() {
$(document).on("scroll", onScroll);
//smoothscroll
$('a[href^="#"]').on('click', function (e) {
e.preventDefault();
$(document).off("scroll");
$('a').each(function() {
$(this).removeClass('active');
})
$(this).addClass('active');
var target = this.hash,
menu = target;
$target = $(target);
$('html, body').stop().animate({
'scrollTop': $target.offset().top+2
}, 500, 'swing', function() {
window.location.hash = target;
$(document).on("scroll", onScroll);
});
});
});
function onScroll(event){
var scrollPos = $(document).scrollTop();
$('a').each(function() {
var currLink = $(this);
var refElement = $(currLink.attr("href"));
if (refElement.position().top <= scrollPos && refElement.position().top + refElement.height() > scrollPos) {
$('a').removeClass("active");
currLink.addClass("active");
}
else{
currLink.removeClass("active");
}
});
}
Проблема возникает в том, что у меня есть несколько меню которые видны при разных размерах экрана. Я изо всех сил пытаюсь изменить активный класс на оба пункта меню одновременно.
Любые предложения будут высоко оценены
Решил, но это не очень. Просто дублируйте код и добавьте в разные идентификаторы для отдельных меню. Я уверен, что есть лучший способ сделать это ??? – fatzak