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

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

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

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

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

Q&A

解決済

1回答

514閲覧

ハンバーガーメニューが閉じません

OdwRuEawfvOdrP7

総合スコア1

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

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

0グッド

0クリップ

投稿2020/06/25 05:23

前提・実現したいこと

ハンバーガーメニュー内の文字をクリックした際に、同時にハンバーガーメニューを
閉じるようにしたいです。
今のままでは、ハンバーガーメニュー内の文字をクリックしてもハンバーガーメニューが開いたままです。プログラミングに詳しい方、ご教示お願い致します。

また、こちらはcssのみで作成しております。

何卒宜しくお願い致します!

発生している問題・エラーメッセージ

ハンバーガーメニュー内の文字をクリックしても、ハンバーガーメニューが閉じません。

該当のソースコード

HTML

<input id="menu" type="checkbox" /> <label for="menu" class="open"><i class="fas fa-bars"></i></label> <label for="menu" class="back"></label> <aside class="aside"> <label for="menu" class="close">×</label> <nav> <div> </div> <ul class="aside_list"> <li><a href="#about">テキスト</a></li> <li><a href="#skill">テキスト</a></li> <li><a href="#strength">テキスト</a></li> <li><a href="#site">テキスト</a></li> <li><a href="#repro">テキスト</a></li> <li><a href="#contact">テキスト</a></li> </ul> </nav> </aside>

CSS
.open,
.close {
display: block;
font-size: 30px;
padding-left: 10px;
}

.open {
position: absolute;
top: 0;
z-index: 10;
}
.aside {
width: 250px;
position: absolute;
left: -250px;
height: 100%;
transition: all 0.2s;
background: #ffffff;
z-index: 100;
top: 0;
}

input[type="checkbox"]:checked ~ .aside {
left: 0;
}

input[type="checkbox"]:checked ~ .back {
position: absolute;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.8) ;
z-index: 50;
}

試したこと

input[type="checkbox"]:none(:target) {
left:-250px;
}

としても、現状変化なしでした。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

以下のようにすればいいのでは?

HTML

1<ul class="aside_list"> 2 <li><a href="#about"><label for="menu">テキスト</label></a></li> 3 <li><a href="#skill"><label for="menu">テキスト</label></a></li> 4 <li><a href="#strength"><label for="menu">テキスト</label></a></li> 5 <li><a href="#site"><label for="menu">テキスト</label></a></li> 6 <li><a href="#repro"><label for="menu">テキスト</label></a></li> 7 <li><a href="#contact"><label for="menu">テキスト</label></a></li> 8</ul>

投稿2020/06/25 05:44

root_jp

総合スコア4666

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

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

OdwRuEawfvOdrP7

2020/06/25 06:00

ご回答ありがとうございます。 root_jp様のコードを試してみましたところ、 ハンバーガーメニューは閉じるようになりましたが、<a>のページ内リンクが利きませんでした。 せっかくなのに申し訳ございません。 何か解決策がございましたら、教えていただければ幸いです。
root_jp

2020/06/25 06:23

どうやらHTMLだけで解決するのは難しいようですね。 以下に同じような質問があったので参考にしてみてください。 https://teratail.com/questions/163080 私が提示したコードは、<a>タグの中に<label>タグを書いてますが、 これはHTMLの文法上よろしくないという事も上記の質問に書いてますので、 <label><a>という順序にしたほうがまだいいみたいですね。
OdwRuEawfvOdrP7

2020/06/28 11:11

リンクまで付けて頂き、ありがとうございます。 jsを追加しまして、修正したいと思います。 ご回答いただき誠にありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問