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

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

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

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

メニュー

メニューは、UIにおける仕組みであり、ユーザに機能の表示と実行する手段を与えます。

レスポンシブWebデザイン

レスポンシブWebデザイン(RWD)は、スクリーンのサイズ、プラットフォーム、オリエンテーションに基づいて様々なデバイスで最適のサイトを生成するのウェブデザインとその開発のアプローチ方法を呼びます。

jQuery

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

Q&A

解決済

1回答

1264閲覧

アコーディオンメニューでコンテンツ多くなると要素が被ってしまいます

niconic73027793

総合スコア215

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

メニュー

メニューは、UIにおける仕組みであり、ユーザに機能の表示と実行する手段を与えます。

レスポンシブWebデザイン

レスポンシブWebデザイン(RWD)は、スクリーンのサイズ、プラットフォーム、オリエンテーションに基づいて様々なデバイスで最適のサイトを生成するのウェブデザインとその開発のアプローチ方法を呼びます。

jQuery

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

0グッド

0クリップ

投稿2021/10/31 03:32

編集2021/10/31 04:58

アコーディオンメニューを作成してます。

コンテンツが少ないときは、通常に動作するのですが、

リンク内容

上記のように普通に動作します。

しかし、コンテンツが増えてくると

リンク内容
上記のように、関東地方をクリックすると
コンテンツが被ってしまいます。

どのようにすれば、コンテンツが増えてもコンテンツが被らないように出来るでしょうか?

試したこと

style:height:auto にしたら広がりましたが、アコーディオンのマイナスボタンを押しても
高さが戻りませんでした。

htmlが下記で

<div class="contents_box"> <h3 class="contentBoxTitle">対応可能エリア</h3> <div class="area_inner"> <input id="acd-check1" class="acd-check" type="checkbox"> <label class="acd-label areaTitle" for="acd-check1">北海道・東北地方</label> <ul class="areaList"> <li><a href="#">北海道</a></li> <li><a href="#">宮城県</a></li> <li><a href="#">山形県</a></li> <li><a href="#">福島県</a></li> </ul> <input id="acd-check2" class="acd-check" type="checkbox"> <label class="acd-label areaTitle" for="acd-check2">北陸・信越地方</label> <ul class="areaList"> <li><a href="#">新潟県</a></li> <li><a href="#">富山県</a></li> <li><a href="#">石川県</a></li> <li><a href="#">福井県</a></li> <li><a href="#">長野県</a></li> </ul> <input id="acd-check3" class="acd-check" type="checkbox"> <label class="acd-label areaTitle" for="acd-check3">関東地方</label> <ul class="areaList"> <li><a href="#">茨城県</a></li> <li><a href="#">栃木県</a></li> <li><a href="#">群馬県</a></li> <li><a href="#">山梨県</a></li> <li><a href="#">埼玉県</a></li> <li><a href="#">千葉県</a></li> <li><a href="#">東京都</a></li> <li><a href="#">神奈川県</a></li> <li><a href="#">茨城県</a></li> <li><a href="#">栃木県</a></li> <li><a href="#">群馬県</a></li> <li><a href="#">山梨県</a></li> <li><a href="#">埼玉県</a></li> <li><a href="#">千葉県</a></li> <li><a href="#">東京都</a></li> <li><a href="#">神奈川県</a></li> <li><a href="#">茨城県</a></li> <li><a href="#">栃木県</a></li> <li><a href="#">群馬県</a></li> <li><a href="#">山梨県</a></li> <li><a href="#">埼玉県</a></li> <li><a href="#">千葉県</a></li> <li><a href="#">東京都</a></li> <li><a href="#">神奈川県</a></li> </ul> <input id="acd-check4" class="acd-check" type="checkbox"> <label class="acd-label areaTitle" for="acd-check4">東海地方</label> <ul class="areaList"> <li><a href="#">岐阜県</a></li> <li><a href="#">静岡県</a></li> <li><a href="#">愛知県</a></li> <li><a href="#">三重県</a></li> </ul> <input id="acd-check5" class="acd-check" type="checkbox"> <label class="acd-label areaTitle" for="acd-check5">関西地方</label> <ul class="areaList"> <li><a href="#">滋賀県</a></li> <li><a href="#">京都府</a></li> <li><a href="#">大阪府</a></li> <li><a href="#">兵庫県</a></li> <li><a href="#">奈良県</a></li> <li><a href="#">和歌山県</a></li> </ul> <input id="acd-check6" class="acd-check" type="checkbox"> <label class="acd-label areaTitle" for="acd-check6">中国・四国地方</label> <ul class="areaList"> <li><a href="#">岡山県</a></li> <li><a href="#">広島県</a></li> <li><a href="#">山口県</a></li> <li><a href="#">愛媛県</a></li> <li><a href="#">香川県</a></li> </ul> <input id="acd-check7" class="acd-check" type="checkbox"> <label class="acd-label areaTitle" for="acd-check7">九州・沖縄地方</label> <ul class="areaList"> <li><a href="#">福岡県</a></li> <li><a href="#">佐賀県</a></li> <li><a href="#">長崎県</a></li> <li><a href="#">熊本県</a></li> <li><a href="#">大分県</a></li> <li><a href="#">鹿児島県</a></li> </ul> </div> </div>

css が下記です

ul.areaList { width: 100%; position: relative; font-size: 100%; list-style: none; /* margin: 0 0 0px 0; */ visibility: hidden; transition: 0.5s; height: auto; opacity: 0; } ul, ol { margin: 1 em 0 1.5 em 1.5 em ; padding-left: 0; } *, ::after, ::before { background-repeat: no-repeat; box-sizing: inherit; } @media (min-width: 768px) .areaTitle { margin-bottom: 20px; font-size: 120%; } .acd-label { display: block; } .areaTitle { position: relative; margin-bottom: 20 px ; font-size: 100%; border-bottom: 2 px solid #172d81; padding-bottom: 5 px ; cursor: pointer;

PC/スマホ 両方ともコンテンツが被さってしまいますね。

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

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

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

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

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

hatena19

2021/10/31 04:26

HTMLコード、CSSコードを追記してください。
niconic73027793

2021/10/31 04:40

うっかり忘れていました。 今、追記させて頂きました。
guest

回答1

0

ベストアンサー

メニューが開いたときのコードが提示されていないので、検証ツールから引っ張ってきました。
下記のようにすれば被らないようになります。

css

1ul.areaList { 2 width: 100%; 3 position: relative; 4 font-size: 100%; 5 list-style: none; 6 margin: 0 0 0 0; 7 visibility: hidden; 8 transition: 0.5s; 9 height: 0; /* ここは0 */ 10 opacity: 0; 11} 12 13.acd-check:checked + .acd-label + .areaList { 14 /* height: 120px; ここをautoに修正 */ 15 height: auto; 16 opacity: 1; 17 visibility: visible; 18}

ただし、この方法だと高さがアニメーションしません。height: auto;はアニメーション非対応ですので。

高さをmax-heightで指定するという方法でアニメーションさせることができますが、コンテンツが少ないメニューはアニメーションが速くなるというデメリットがあります。
エリア毎に max-height の設定値を変更するとか、メディアクエリでも変更するとか細かく設定すればある程度は対処できますが面倒ですね。

css

1ul.areaList { 2 width: 100%; 3 position: relative; 4 font-size: 100%; 5 list-style: none; 6 margin: 0 0 0 0; 7 visibility: hidden; 8 transition: 0.5s; 9 max-height: 0; 10 opacity: 0; 11} 12 13.acd-check:checked + .acd-label + .areaList { 14 max-height: 120px; 15 opacity: 1; 16 visibility: visible; 17}

jQueryを使っていいのなら、jQueryの.slideToggle()を使えば簡単にアニメーションで開いたり閉じたりできます。

投稿2021/10/31 05:01

hatena19

総合スコア34075

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

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

niconic73027793

2021/10/31 05:15

非常にわかりやすい説明ありがとうございます! max-height を使えばアニメーションもできるのですね。 助かりました<(_ _)>
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問