アンカーリンクでURLに「#hoge」のようなパラメータを残さずスクロールさせる方法
アンカータグをクリックしてもブラウザのURL欄に「#hoge」のようなハッシュを残さずに指定の要素までスクロールできるというコーディングデータがあった。しかも他ページからハッシュ付きのURLで遷移してきてもスクロール後にハッシュが消えるような挙動を取っており、どういう手段なのか気になったのでメモ。
サンプル
https://taitan916.info/sample/anchor_link/
ソースコード
<html lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>アンカータグでスクロールテスト</title> </head> <body> <a href="#test1">test1</a> <a href="#test2">test2</a> <a href="#test3">test3</a> <div style="background-color: #f00; height: 1000px;" id="test1"></div> <div style="background-color: #0f0; height: 1000px;" id="test2"></div> <div style="background-color: #00f; height: 1000px;" id="test3"></div> <script type="text/javascript" src="https://code.jquery.com/jquery-3.5.1.js"></script> <script type="text/javascript"> $(function(){ const hash = decodeURI(location.hash); if(hash){ $("html, body").animate({scrollTop:$(hash).offset().top}); window.history.replaceState(null, '', window.location.pathname + window.location.search); } $('a[href^="#"]').click(function(){ const href= $(this).attr("href"); const target = $(href == "#" || href == "" ? 'html' : href); $("html, body").animate({scrollTop:target.offset().top}); window.history.replaceState(null, '', window.location.pathname + window.location.search); return false; }); }); </script> </body> </html>
他ページから遷移してきた際は「if(hash){」のところで、リンクをクリックした際は「$('a[href^="#"]').click(function(){」で検知しスクロールした後にpushStateでハッシュを削除している。尚、ハッシュは特に削除しなくてもいい場合は以下の形でOK。
$(function(){ $('a[href^="#"]').click(function(){ const href= $(this).attr("href"); const target = $(href == "#" || href == "" ? 'html' : href); $("html, body").animate({scrollTop:target.offset().top}); return false; }); });
所感
URLはできるだけシンプルな方が良い派なので今後も使っていきたいところ。
関連記事
-
-
DateTimePickerで特定日にClassを付与&選択不可にする方法
jQueryプラグインのDateTimePikerで特定の日にClassを付与し ...
-
-
「slick」でブラウザ幅がPCの場合はスライダーを表示し、スマホ幅の場合はスライダー無しにする方法
slickプラグインで画像スライダーを設置しているページがあり、PCのブラウザ幅 ...
-
-
jQueryにて複数のajax処理のレスポンスをまとめて表示する方法
同時にajax処理を行う際、挙動やコードの書き方に悩まされることが多い。例えばA ...
-
-
JSやjQueryで動的に追加した要素に対して「slick」でスライダーを実行する方法
外部サーバからAjax等で画像URLを取得したものをimgタグとしてページ内に描 ...
-
-
FlashとjQueryを組み合わせたプラグインでWebカメラで撮影した画像をアップロード
FlashとjQueryを組み合わせたプラグインを用いてWebカメラで撮影した画 ...