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

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

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

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

jQuery

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

CSS

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

Q&A

解決済

1回答

1378閲覧

アコーディオンの次の要素が動かず固定してしまう

ayumi0925

総合スコア13

JavaScript

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

jQuery

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

CSS

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

0グッド

1クリップ

投稿2019/03/05 05:07

編集2019/03/05 06:56

アコーディオンで次の要素が動かず被ってしまう

jqueryでアコーディオンを作っているのですが、アコーディオンの動作的には問題ないものの、次の要素が動かずその場に固定しているため、アコーディオンの中身と被ってしまいます。
親ナビは横並びにして幅指定、子ナビは100%表示にしたいです。
![イメージ説明

html

1<div class="accordion"> 2 <dl class=acc_inner"> 3 <dt>親ナビ1</dt> 4 <dd>子ナビ</dd> 5 </dl> 6 <dl class=acc_inner"> 7 <dt>ナビ1</dt> 8 <dd>子ナビ</dd> 9 </dl> 10         <dl class=acc_inner"> 11 <dt>ナビ1</dt> 12 <dd>子ナビ</dd> 13 </dl> 14 </div> 15 <p><a href="https://xxx.xxxjp">次に進む</p>

css

1.accordion{ 2 position: relative; 3 width: 100%; 4 top: -310px; 5 left: 105px; 6} 7dt{ 8 position: relative; 9 float: left; 10 width: 266px; 11 margin: 0 10px 0; 12} 13dd{ 14 display: none; 15 position: absolute; 16 top: 95px; 17 left: 0; 18 width: 100%; 19 background: #fff; 20 text-align: center; 21 padding: 30px 0; 22}

javascript

1 $(".accordion dt").click(function(){ 2 $(this).next("dd").slideToggle(); 3 $(this).next("dd").siblings("dd").slideUp(); 4 $(this).toggleClass("open"); 5 $(this).siblings("dt").removeClass("open"); 6});

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

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

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

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

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

cerfweb

2019/03/05 12:27

<dl class=acc_inner">の部分、ダブルクォーテーションが欠けていますよ。
ayumi0925

2019/03/05 12:44

すみません、記載漏れでした。 ダブルクォーテーションがあってもイメージ通り動きませんでした。 よろしくお願いいたします。
guest

回答1

0

ベストアンサー

jQuery

1$(this).next("dd").siblings("dd").slideUp();

上記の書き方では.siblingsが存在しない要素を指しています。
以下のようにすれば期待通りに動くのではと思いますがいかがでしょうか。

jQuery

1$('.accordion dt').on('click', function(){ 2 var $this = $(this), 3 acc_inner = $this.parent().siblings('.acc_inner'); 4 5 acc_inner.children('dd').slideUp(); 6 acc_inner.children('dt').removeClass('open'); 7 $this.toggleClass('open').next('dd').slideToggle(); 8});

補足:繰り返し使うものは$this = $(this)のように変数にした方が処理が早くなります。

投稿2019/03/05 12:27

cerfweb

総合スコア1899

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

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

ayumi0925

2019/03/06 02:57 編集

ありがとうございます! 記載いただいたコードで試してみたのですが、直らずでした... cssも自分で確認してみたところ、「次に進む」にpositionかかっていたのが原因でした。(記載漏れです...) hieghtを指定して、親ナビにpositionで場所指定したら直りました! 丁寧に解説していただいたのにこちらの安易なミスでお時間取らせてしまってすみませんでした。 またわからないことがありましたら、よろしくお願いいたします!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問