Используйте jQuery для проверки события mousewheel без полосы прокрутки
Как проверить движение колесика мыши без полосы прокрутки?
$(document).mousewheel(function() {
clicker.html("a7a");
});
4 ответа
Решение
Я настоятельно рекомендую вам использовать этот плагин jQuery: PLUGIN
Без плагина попробуйте этот пример: ПРИМЕР
HTML:
<div id='foo' style='height:300px; width:300px; background-color:red'></div>
Javascript:
$('#foo').bind('mousewheel', function(e) {
if(e.originalEvent.wheelDelta / 120 > 0) {
alert('up');
} else {
alert('down');
}
});
На div нет полосы прокрутки, но событие колеса обнаружено.
Используйте этот код
$('#foo').bind('mousewheel DOMMouseScroll', function (event) {
if (event.originalEvent.wheelDelta > 0 || event.originalEvent.detail < 0) {
//up
}
else {
//down
}
});
И, если вы вообще не хотите использовать плагин (IE8, Chrome, Firefox, Safari, Opera...), просто сделайте это:
if (document.addEventListener) {
document.addEventListener("mousewheel", MouseWheelHandler(), false);
document.addEventListener("DOMMouseScroll", MouseWheelHandler(), false);
} else {
sq.attachEvent("onmousewheel", MouseWheelHandler());
}
function MouseWheelHandler() {
return function (e) {
// cross-browser wheel delta
var e = window.event || e;
var delta = Math.max(-1, Math.min(1, (e.wheelDelta || -e.detail)));
//scrolling down?
if (delta < 0) {
alert("Down");
}
//scrolling up?
else {
alert("Up");
}
return false;
}
}
Живой пример: http://jsfiddle.net/CvCc6/1/
Это всего лишь обновление ответа @ Аарона с использованием нового события "колесо", описанного здесь: https://developer.mozilla.org/en-US/docs/Web/Events/wheel
$('#foo').on('wheel', function(e){
if(e.originalEvent.deltaY < 0) {
console.log('scrolling up !');
} else{
console.log('scrolling down !');
}
});
Вы также можете использовать deltaX
чтобы увидеть горизонтальную прокрутку, или deltaZ
если у вас есть какая-то сумасшедшая 3D вещь.