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

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

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

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

8091閲覧

javaScriptで現在のURLを取得して該当するローカルナビにクラスを付与したい。

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

1クリップ

投稿2016/10/19 00:55

###前提・実現したいこと
現在地を取得してマッチしたURLを持ったローカルナビのリストにクラスを付与したい。

1 現在のURLを取得。
2 #localNavの中のa要素のhref属性に、1で取得したURLと同一の物を探す。
3 マッチした要素があったら、そのURLを持つ親のliにクラスcurrentを付与する。

ちなみに現在のjsコードは中途半端ですが、a要素href属性に、現在のURLとマッチする物があったらliにクラスを付与する(全部)となっています。

###発生している問題・エラーメッセージ
現在URLとローカルナビ内のhrefの取得までうまくいったのと思うのですが、
マッチしたhrefが見つかった場合のliへのクラス処理の方法がわかりません。

###該当のソースコード

<ul id="localNav"> <li><a href="/aaaa/bbbbbbbbbb/index.html">テキスト</a></li> <li><a href="/aaaa/bbbbbbbbbb/ccc01.html">テキスト</a></li> <li><a href="/aaaa/bbbbbbbbbb/ccc02.html">テキスト</a></li> <li><a href="/aaaa/bbbbbbbbbb/ccc03.html">テキスト</a></li> <li><a href="/aaaa/bbbbbbbbbb/ccc04.html">テキスト</a></li> <li><a href="/aaaa/bbbbbbbbbb/ccc/index.html">テキスト</a></li> </ul> <script> var nav = document.getElementById('localNav'), child = nav.getElementsByTagName('a'), path = location.pathname.slice(16); // 現在のパス16番目以降取得 for(var i = 0; i < child.length; i++){ var href = child[i].getAttribute('href').slice(16); //a要素のhrefのURL16番目以降を配列で取得 if(href === path){ for(var j = 0; j < nav.children.length; j++){ nav.children[j].classList.add('current'); } }else{ } } </script>

###試したこと
href自体は配列で取得されているはずなので、マッチした配列番号に対してクラスを振るなど考えましたが、そもそも配列番号を取得する方法がわかりませんでした。

###補足情報(言語/FW/ツール等のバージョンなど)
.slice()でURLを取得していますが、下2階層のURL取得方法でいい方法があれば教えてください。
こういう書き方の方が良いなどあれば大歓迎です。

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

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

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

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

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

guest

回答2

0

javascript

1<script src="https://code.jquery.com/jquery-2.2.4.min.js"></script> 2<script type="text/javascript"> 3$(window).load(function () { 4 $('#localNav').find('a').each(function () { 5 if (location.pathname == $(this).attr('href')) { 6 $(this).parent('li').addClass('current'); 7 } 8 }); 9}); 10</script>

jquery 使用していいならばこれでいけると思います。

投稿2016/10/19 03:35

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

退会済みユーザー

退会済みユーザー

2016/10/20 00:05

ありがとうございます。 プレーンなjavascriptでお願いしたいです。
guest

0

ベストアンサー

自己解決しました。
原因としては、
・for文に対する理解が足りなかった。
・配列の使い方をわかってなかった。
などがあります。

もっとより良い書き方があるかとは思いますが現状の知識ではこれが限界でした。

ありがとうございます!

var nav = document.getElementById('localNav'), a = nav.getElementsByTagName('a'), path = location.pathname, //現在のパス取得 url = []; //後に取得したURLを入れる空の配列を作成 for (var i = 0; i < a.length; i++) { var href = a[i].getAttribute('href'); //localNavの中のa要素すべてのhref属性のパスを取得 url[i] = href; //それを配列に格納 } var listPath = url.indexOf(path); //現在のパスと、ローカルのパスが一致する配列番号を取得する nav.children[listPath].classList.add('current'); </script>

投稿2016/10/20 01:51

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問