На жаль, немає прямого способу сказати це.
Я б сказав, якщо ви зможете перепроектувати свою програму так, щоб вона не залежала від цього типу потоку, перейдіть до цього.
Якщо ні, то обхідне рішення, яке я можу придумати, - це відстежувати ініційовані користувачем сувої та перевіряти, чи не прокручував браузер чи користувач.
Ось приклад, який я зібрав, який робить це досить добре (за винятком браузерів, в яких історія jQuery має проблеми).
Вам потрібно запустити це локально, щоб мати можливість повністю його перевірити (jsFiddle / jsbin погано підходить, оскільки вони iFrame вміст).
Ось тестові приклади, які я перевірив:
- Завантаження сторінки -
userScrollцеfalse
- Прокрутка за допомогою миші / клавіатури -
userScrollстаєtrue
- Клацніть на посилання, щоб перейти на сторінку внизу -
userScrollстаєfalse
- Клацніть Назад / Вперед -
userScrollстає false;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<script src="http://code.jquery.com/jquery-1.6.1.min.js"></script>
<script type="text/javascript" src="https://raw.github.com/tkyk/jquery-history-plugin/master/jquery.history.js"></script>
</head>
<body>
<span> hello there </span><br/>
<a href="#bottom"> click here to go down </a>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
<a name="bottom"> just sitting </a>
</body>
<script type="text/javascript">
var userScroll = false;
function mouseEvent(e) {
userScroll = true;
}
$(function() {
$.history.init(function(hash){
userScroll = false;
});
$(document).keydown(function(e) {
if(e.which == 33
|| e.which == 34
|| e.which == 32
|| e.which == 38
|| e.which == 40
|| (e.ctrlKey && e.which == 36)
|| (e.ctrlKey && e.which == 35)
) {
userScroll = true;
}
});
if(window.addEventListener) {
document.addEventListener('DOMMouseScroll', mouseEvent, false);
}
document.onmousewheel = mouseEvent;
$('a[href*=#]').click(function() {
userScroll = false;
});
$(document).scroll( function(){
console.log('Scroll initiated by ' + (userScroll == true ? "user" : "browser"));
});
});
</script>
</html>
Примітки:
- Це не відстежує прокрутку, коли користувач перетягує смугу прокрутки за допомогою миші. До цього можна додати ще трохи коду, який я залишив для вас вправою.
event.keyCodes може відрізнятися залежно від ОС, тому вам, можливо, доведеться змінити це відповідно.
Сподіваюся, це допомагає!