Как добавить активный класс, когда пользователь прокручивает БЕЗ URL ссылки
Я создал инструмент навигации, который изменяет активный класс на основе раздела страницы, как этот пример учебника: http://stanhub.com/tutorials/change-active-state-in-sticky-navigation-on-scroll/
У меня такой вопрос: как мне отредактировать этот код, чтобы удалить / предотвратить отображение заголовка ссылки хэштега в URL браузера?
Моя текущая работа:
$j(document).ready(function () {
$j(document).on("scroll", onScroll);
//smoothscroll
$j('a[href^="#"]').on('click', function (e) {
e.preventDefault();
$j(document).off("scroll");
$j('a').each(function () {
$j(this).removeClass('active');
})
$j(this).addClass('active');
var target = this.hash,
menu = target;
$jtarget = $j(target);
$j('html, body').stop().animate({
'scrollTop': $jtarget.offset().top+2
}, 500, 'swing', function () {
window.location.hash = target;
$j(document).on("scroll", onScroll);
});
});
});
function onScroll(event){
var scrollPos = $j(document).scrollTop();
$j('#slide-nav a').each(function () {
var currLink = $j(this);
var refElement = $j(currLink.attr("href"));
if (refElement.position().top <= scrollPos && refElement.position().top + refElement.height() > scrollPos) {
$j('#slide-nav a').removeClass("active");
currLink.addClass("active");
}
else{
currLink.removeClass("active");
}
});
}
2 ответа
Решение
Нечто подобное я думаю:
var t = null;
$j('a[href^="#"]').on('click', function (e) {
e.preventDefault();
$j(document).off("scroll");
$j('a').each(function () {
$j(this).removeClass('active');
})
$j(this).addClass('active');
t = $(this).attr('href');
var target = t,
menu = target;
$jtarget = $j(target);
$j('html, body').stop().animate({
'scrollTop': $jtarget.offset().top+2
}, 500, 'swing', function () {
t = target;
$j(document).on("scroll", onScroll);
});
});
});
function onScroll(event){
var scrollPos = $j(document).scrollTop();
$j('#slide-nav a').each(function () {
var currLink = $j(this);
var refElement = $j(currLink.attr("href"));
if (refElement.position().top <= scrollPos && refElement.position().top + refElement.height() > scrollPos) {
$j('#slide-nav a').removeClass("active");
currLink.addClass("active");
}
else{
currLink.removeClass("active");
}
});
}
Это код, который работал для меня:
$j(document).ready(function () {
$j(document).on("scroll", onScroll);
var t = null;
$j('a[href^="#"]').on('click', function (e) {
e.preventDefault();
$j(document).off("scroll");
$j('a').each(function () {
$j(this).removeClass('active');
})
$j(this).addClass('active');
t = $j(this).attr('href');
var target = t,
menu = target;
$jtarget = $j(target);
$j('html, body').stop().animate({
'scrollTop': $jtarget.offset().top+2
}, 500, 'swing', function () {
t = target;
$j(document).on("scroll", onScroll);
});
});
});
function onScroll(event){
var scrollPos = $j(document).scrollTop();
$j('#slide-nav a').each(function () {
var currLink = $j(this);
var refElement = $j(currLink.attr("href"));
if (refElement.position().top <= scrollPos && refElement.position().top + refElement.height() > scrollPos) {
$j('#slide-nav a').removeClass("active");
currLink.addClass("active");
}
else{
currLink.removeClass("active");
}
});
}