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

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

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

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

Q&A

解決済

1回答

766閲覧

Jqueryでyoutube みたいにクリックすると返信ができるスライドを出したい

atage517

総合スコア36

jQuery

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

0グッド

0クリップ

投稿2020/08/04 03:17

やりたいこと

postがあり返信するをクリックすると返信ようのコメント欄を出したいのですが、jqueryでthis のやり方がわからないのでここで質問させていただきます。

<% @posts.each do |post| %> <div class="posts-index-item"> . . . <div class="post-menus-left"> <i class="fas fa-reply-all"></i> </div> </div> <div class="reply-form"> <div class="reply-form-body"> <input name="title" class="title-area" placeholder="回答に質問または返信する"> </div> </div> <% end %>

というコードがあり、任意の <i class="fas fa-reply-all"></i> をクリックするとその投稿のコメント欄のみ表示させたいのですが、そのやり方がわかりません。

$(document).on('turbolinks:load', function(){ $('.fa-reply-all').click(function(){ $('.reply-form').slideToggle(); }); });

これでは全てのコメント欄が表示されてしまうので何かいい方法を教えていただき

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

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

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

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

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

guest

回答1

0

ベストアンサー

関連する要素たちをdivで囲って、eachで回して、
先祖要素から指定するのはどうでしょうか?

html

1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4 <meta charset="UTF-8"> 5 <title>Document</title> 6 <style> 7 .reply-form { 8 display: none; 9 } 10 </style> 11</head> 12<body> 13 <div class="box"> 14 <div class="post-menus-left"> 15 <i class="fas fa-reply-all">表示</i> 16 </div> 17 18 <div class="reply-form"> 19 <div class="reply-form-body"> 20 <input name="title" class="title-area" placeholder="回答に質問または返信する"> 21 </div> 22 </div> 23 </div> 24 25 <div class="box"> 26 <div class="post-menus-left"> 27 <i class="fas fa-reply-all">表示</i> 28 </div> 29 30 <div class="reply-form"> 31 <div class="reply-form-body"> 32 <input name="title" class="title-area" placeholder="回答に質問または返信する"> 33 </div> 34 </div> 35 </div> 36 <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> 37 <script> 38 $(function() { 39 $(".box").each(function() { 40 $("i", this).on('click', function() { 41 $(this).closest(".box").find(".reply-form").slideToggle(); 42 }) 43 }) 44 }); 45 </script> 46</body> 47</html> 48

投稿2020/08/04 05:46

akihiro3

総合スコア955

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

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

atage517

2020/08/04 06:13

akihiro3 ありがとうございます。その方法でもできました しかし、問題は <% @post.answers.each do |answer| %> <div class="posts-index-item"> . . <div class="post-menus-left"> <i class="fas fa-reply-all"></i> </div> </div> <!-- ここからreply-formは別で --> <div class="reply-form"> <div class="reply-form-body"> <input name="title" class="title-area" placeholder="回答に質問または返信する"> </div> </div> <% end %> となっています。  Post と reply のフォームは一体化させないで任意のpostの下にそれに値するreply-fromだけを表示させたいです。
atage517

2020/08/04 06:25

posts-index-item をさらに囲うことでできました! ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問