質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

3回答

2054閲覧

<a>リンクでページ内移動を制御したい jQuery

WPJ

総合スコア23

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2021/11/18 03:17

前提・実現したいこと

以下サイトなのですが、
https://infinity-mobius.com/solution

カテゴリのタグを押すとそれぞれのコンテンツを表示させるよう開発しました。
以下ページを参考としております。

https://coco-factory.jp/ugokuweb/move01/5-4-1/

しかし、<a>タグを使ったコードなので、
タブをクリックすると、ページ内リンクで下に移動してしまいます。
タブとしての機能だけ反映したいのですが、ページ遷移させないようにできるでしょうか。

jQuery

<script type="text/javascript"> //任意のタブにURLからリンクするための設定 function GethashID (hashIDName){ if(hashIDName){ //タブ設定 $('.tab li').find('a').each(function() { //タブ内のaタグ全てを取得 var idName = $(this).attr('href'); //タブ内のaタグのリンク名(例)#lunchの値を取得 if(idName == hashIDName){ //リンク元の指定されたURLのハッシュタグ(例)http://example.com/#lunch←この#の値とタブ内のリンク名(例)#lunchが同じかをチェック var parentElm = $(this).parent(); //タブ内のaタグの親要素(li)を取得 $('.tab li').removeClass("active"); //タブ内のliについているactiveクラスを取り除き $(parentElm).addClass("active"); //リンク元の指定されたURLのハッシュタグとタブ内のリンク名が同じであれば、liにactiveクラスを追加 //表示させるエリア設定 $(".area").removeClass("is-active"); //もともとついているis-activeクラスを取り除き $(hashIDName).addClass("is-active"); //表示させたいエリアのタブリンク名をクリックしたら、表示エリアにis-activeクラスを追加 } }); } } //タブをクリックしたら $('.tab a').on('click', function() { var idName = $(this).attr('href'); //タブ内のリンク名を取得 GethashID (idName);//設定したタブの読み込みと return false;//aタグを無効にする }); // 上記の動きをページが読み込まれたらすぐに動かす $(window).on('load', function () { $('.tab li:first-of-type').addClass("active"); //最初のliにactiveクラスを追加 $('.area:first-of-type').addClass("is-active"); //最初の.areaにis-activeクラスを追加 var hashName = location.hash; //リンク元の指定されたURLのハッシュタグを取得 GethashID (hashName);//設定したタブの読み込み }); </script>

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

ベストアンサー

stopImmediatePropagationで、他のイベントリスナを止めてしまうのがお手軽かもしれません。

js

1$('.tab a').on('click', function(e) { // 変更 2 e.stopImmediatePropagation() // 変更 3 var idName = $(this).attr('href'); //タブ内のリンク名を取得 4 GethashID (idName);//設定したタブの読み込みと 5 return false;//aタグを無効にする 6});

ただ、他のクリックイベントを全て止めてしまうので、他に影響が出ないか、将来的に問題はないか、確かめる必要があると思います。


ややお手軽でない方法としては、hrefではなくてdata-属性を使うのがいいと思います。

投稿2021/11/18 03:35

編集2021/11/18 03:37
Lhankor_Mhy

総合スコア36960

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

WPJ

2021/11/18 04:43

上記ソースで一発でなおりました。 ありがとうございました。 他に影響が出ないか、将来的に問題はないか、追加で検討したいと思います。
Lhankor_Mhy

2021/11/18 06:08

お役に立てたようで何よりです。 このやり方は、ほんとに「とりあえず手っ取り早く」というものですので、お含みおきください。
guest

0

タブきりかえするならlabelでラジオボタンを制御する手もあります

CSS

1<style> 2[name=tab]{ 3display:none; 4} 5nav ul{ 6display:flex; 7} 8nav ul,nav,li{ 9 list-style:none; 10margin:0; 11padding:0; 12} 13 14#tab1:not(:checked) ~ * #area1, 15#tab2:not(:checked) ~ * #area2, 16#tab3:not(:checked) ~ * #area3{ 17display:none; 18} 19#tab1:checked ~ * [for=tab1], 20#tab2:checked ~ * [for=tab2], 21#tab3:checked ~ * [for=tab3]{ 22background-Color:yellow; 23} 24</style> 25<input type="radio" name="tab" value="1" id="tab1" checked> 26<input type="radio" name="tab" value="2" id="tab2"> 27<input type="radio" name="tab" value="3" id="tab3"> 28<nav> 29<ul> 30<li><label for="tab1">1</label></li> 31<li><label for="tab2">2</label></li> 32<li><label for="tab3">3</label></li> 33</ul> 34</nav> 35<div> 36<div id="area1">area1</div> 37<div id="area2">area2</div> 38<div id="area3">area3</div> 39</div>

投稿2021/11/18 03:53

yambejp

総合スコア116734

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

カテゴリのタグをスムーススクロール対象から除外すればよいと思います。
特定のリンクをスムーススクロールさせないように除外させる | g lance

投稿2021/11/18 03:31

harami_

総合スコア128

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問