前提・実現したいこと
HTML、CSS、JavaScriptでWebページを作成しています。
俗にいうハンバーガーメニューの実装中に以下のエラー、不具合が起きました。
ここに質問の内容を詳しく書いてください。
発生している問題・エラーメッセージ
ハンバーガーメニュー(三となっている部分をクリックすると展開するナビゲーション)を実装したいのですが、中身にあたるナビ部分が隠れずに露出してしまいます。 Google Chromeのデベロッパーツールで確認するとスタイル(nav.menu)の部分に打ち消し線が入ってしまったり、 倀という文字がスタイルの指定部に入ってしまう(fontsize: 10pxが倀fontsize: 10pxとなる)といった不具合が起こりメニューを実装できていません。 メニュー部分以外はCSSが反映されているため、ファイルの指定が誤っているということはないかと思われます。 またメニュー(span)の挙動に関しては問題はないので、nav.menuのスタイルを反映させられれば、解決します。
該当のソースコード
HTML,CSS
1HTML 2```<div class="container"> 3 <nav class="menu"> 4 <ul> 5 <li class="top"><a href="#top">Menu1</a></li> 6 <li class=""><a href="#">Menu2</a></li> 7 <li class=""><a href="#">Menu3</a></li> 8 <li class=""><a href="#">Menu4</a></li> 9 <li class=""><a href="#">Menu5</a></li> 10 </ul> 11 </nav> 12 13 <div class="Toggle"> 14 <span></span> 15 <span></span> 16 <span></span> 17 </div> 18</div>
CSS
.container{ position:fixed; margin-top: -50px; background-color: white; } /* ハンバーガーメニュー */ .menu{ position: fixed; z-index: 2; top: 0; left: 0; background: #fff; color: #000; text-align: center; width: 100%; transform: translateY(-100%); transition: all 0.6s; }/*この部分のスタイルが反映されず打ち消し線が入っていました。*/ .menu ul{ background: #ccc; width: 100%; margin: 0 auto; padding: 0; } .menu ul li{ font-size: 1.1em; list-style-type: none; padding: 0; width: 100%; border-bottom: 1px dotted #333; } .menu ul li:last-child{ padding-bottom: 0; border-bottom: none; } .menu ul li a{ display: block; color: #000; padding: 1em 0; } .menu.active{ transform: translateY(0%); } .Toggle { display: block; position: fixed; right: 13px; top: 12px; width: 42px; height: 42px; cursor: pointer; z-index: 3; } .Toggle span { display: block; position: absolute; width: 30px; border-bottom: solid 3px #000; -webkit-transition: .35s ease-in-out; -moz-transition: .35s ease-in-out; transition: .35s ease-in-out; left: 6px; } .Toggle span:nth-child(1) { top: 9px; } .Toggle span:nth-child(2) { top: 18px; } .Toggle span:nth-child(3) { top: 27px; } .Toggle.active span:nth-child(1) { top: 18px; left: 6px; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg); } .Toggle.active span:nth-child(2), .Toggle.active span:nth-child(3) { top: 18px; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); transform: rotate(45deg); } ### 試したこと 前述した通り、linkの指定が正しいことは確認済み。 後から他のスタイル指定で上書きされているということもありませんでした。 よろしくお願いいたします。 ### 補足情報(FW/ツールのバージョンなど) ページ表示:Google Chrome 76.0.3809.100 エディタ:Atom1.39.1
回答1件
あなたの回答
tips
プレビュー