Web サイトにスライド パネルを設定しました。
アニメーションが終了したら、ハッシュを次のように設定します
function() {
window.location.hash = id;
}
(これはコールバックで、id
が先に割り当てられます)。
これはうまく機能し、ユーザーがパネルをブックマークできるようにし、JavaScript 以外のバージョンを機能させることもできます。
ただし、ハッシュを更新すると、ブラウザーはその場所にジャンプします。これは予想される動作だと思います。
私の質問は、どうすればこれを防ぐことができますか? つまり、ウィンドウのハッシュを変更する方法はありますが、ハッシュが存在する場合、ブラウザを要素にスクロールさせないようにするにはどうすればよいですか? ある種event.preventDefault()
の何か?
jQuery 1.4 とscrollTo プラグインを使用しています。
どうもありがとう!
アップデート
パネルを変更するコードは次のとおりです。
$('#something a').click(function(event) {
event.preventDefault();
var link = $(this);
var id = link[0].hash;
$('#slider').scrollTo(id, 800, {
onAfter: function() {
link.parents('li').siblings().removeClass('active');
link.parent().addClass('active');
window.location.hash = id;
}
});
});