Авто-прокрутка до следующего якоря на колесике мыши
у меня есть 5 якорей на моей html-странице. Есть ли способ, которым страница автоматически прокручивается к следующему якорю ( # ) с помощью одного прокрутки колесика мыши? Есть ли способ, чтобы это произошло независимо от имени якоря? только до следующего якоря.
2 ответов
это работает в Chrome, IE, Firefox, Opera и Safari:
(function() {
var delay = false;
$(document).on('mousewheel DOMMouseScroll', function(event) {
event.preventDefault();
if(delay) return;
delay = true;
setTimeout(function(){delay = false},200)
var wd = event.originalEvent.wheelDelta || -event.originalEvent.detail;
var a= document.getElementsByTagName('a');
if(wd < 0) {
for(var i = 0 ; i < a.length ; i++) {
var t = a[i].getClientRects()[0].top;
if(t >= 40) break;
}
}
else {
for(var i = a.length-1 ; i >= 0 ; i--) {
var t = a[i].getClientRects()[0].top;
if(t < -20) break;
}
}
if(i >= 0 && i < a.length) {
$('html,body').animate({
scrollTop: a[i].offsetTop
});
}
});
})();
Скрипка на http://jsfiddle.net/t6LLybx8/728/
как это работает
чтобы контролировать колесо мыши в большинстве браузеров, используйте $(document).on('mousewheel')
. Firefox является странным, и он требует $(document).on('DOMMouseScroll')
.
чтобы получить направление колеса мыши (вверх или вниз), используйте event.originalEvent.wheelDelta
. Опять же, Firefox является странным, и вы должны использовать -event.originalEvent.detail
.
если направление является отрицательным числом, вы прокручиваете вниз страницы. В этом случае, цикл через каждый тег, начинающийся с первый, до его первого getClientRects()
top is >= 40. (Я использовал 40, если браузер добавляет поле по умолчанию в верхней части окна просмотра.)
если направление является положительным числом, вы прокручиваете до страницы. В этом случае, цикл через каждый тег начинается с последние, до его первого getClientRects()
верх
на delay
переменная предотвращает прокрутку колесика мыши слишком быстро. Вся функция завернута в закрытие, поэтому delay
остается закрытой переменной.
допустим, у вас есть массив идентификаторов.тогда вы можете сделать что-то вроде этого...
var ancherList = ["id1","id2","id3"];
var currentPosition = null;
var mousewheelevent = 'onwheel' in document ? 'wheel' : 'onmousewheel' in document ? 'mousewheel' : 'DOMMouseScroll';
$(document).on(mousewheelevent,function(e){
var scrollToAncher function (id,speed){
spd = speed ? "slow" //deafult value for the animation speed
var ancherTag = $("a[name='"+ id +"']");
$('html,body').animate({scrollTop: ancherTag.offset().top},spd);
}
e.preventDefault();
var delta = e.originalEvent.deltaY ? -(e.originalEvent.deltaY) : e.originalEvent.wheelDelta ? e.originalEvent.wheelDelta : -(e.originalEvent.detail);
if (delta > 0){
console.log("up")
//check your current position and target id
switch(currentPosition){
case null :
case ancherList[0] :
scrollToAncher(ancherList[1]);
currentPosition = ancherList[1];
break;
case ancherList[1] :
currentPosition = ancherList[2];
scrollToAncher(ancherList[2]);
break;
case ancherList[2] :
currentPosition = ancherList[0];
scrollToAncher(ancherList[0]);
break;
}
} else {
console.log("down")
//do the same for mouse wheel down
}
});
код не протестирован.извините, если была синтаксическая ошибка