残念ながら、それを直接伝える方法はありません。
このタイプのフローに依存しないようにアプリを再設計できる場合は、それを選択してください。
そうでない場合、私が考えることができる回避策は、ユーザーが開始したスクロールを追跡し、スクロールがブラウザーまたはユーザーによってトリガーされたかどうかを確認することです。
これは私がまとめた例で、これはかなりうまくいきます(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
OSによって異なる場合があるため、適切に変更する必要がある場合があります。
お役に立てれば!