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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

HTML

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

Q&A

解決済

1回答

2727閲覧

rails erb内でのeach文が上手く表示されない

ko_no

総合スコア16

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

HTML

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

0グッド

0クリップ

投稿2020/06/22 05:21

編集2020/06/22 08:14

前提・実現したいこと

当方railsにて掲示板のようなアプリを作成しております。
画面左の「参加する」ボタン押下でユーザーが特定のグループ(ボタンが配置してあるグループ)に参加する仕組みの実装している途中なのですが、グループ一覧の表示で行き詰りました。
DBのgroupテーブルからグループ名を抽出し、each文でグループ一覧を表示させたいです!

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

添付の画像を見ていただければイメージしやすいかと思うのですが、まずは全てのグループ名の横に「参加する」ボタンを表示したいです!(後々、ユーザーが参加しているグループに「参加中」、参加していないグループに「参加する」を配置する予定です)

イメージ説明

該当のソースコード

groups/index.html.erb

<div class="Main"> <%= render partial: 'layouts/group_index', locals: {groups: @groups} %> </div>

layouts/_group_inde.html.erb

<div class="Main__left"> <div class="Main__left__search"> <div class="Main__left__search-squeeze"> <form action="#" class="Main__left__search-squeeze-box"> <input type="checkbox"> </form> <p>参加中のグループに絞る</p> </div> <form action="#" class="Main__left__search-main"> <input type="text" placeholder="グループを検索" class="Main__left__search-main-text"> <input type="submit" value="検索" class="Main__left__search-main-btn"> </form> </div> <div class="Main__left__group"> <% groups.each do |group| %> <div class="Main__left__group-name"> <%= group.group_name %> </div> <div class="Main__left__group-text">最新テキスト</div> <div class="Main__left__group-time">2020/06/20</div> <%= link_to "参加する", join_group_path(group), class: 'Main__left__group-btn' %> <% end %> </div> </div>

index.scss

&__group{ height: 80px; border-bottom: solid 1px rgb(163, 161, 161); margin: 5px 0px 0px 5px; position: relative; &-name{ font-size: 20px; color: rgb(90, 89, 89); } &-text{ font-size: 15px; color: rgb(146, 145, 145); } &-time{ font-size: 15px; color: rgb(146, 145, 145); } &-btn{ background-color: rgb(107, 107, 107); text-decoration: none; color: white; height: 30px; width: 80px; line-height: 30px; text-align: center; border-radius: 5px; position: absolute; bottom: 3px; right: 3px; } }

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

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

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

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

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

winterboum

2020/06/22 07:56

Main__left__group-btn にどんなCSS設定してますか?
ko_no

2020/06/22 08:15

画面左のグループに設定してあるcssを追記させていただきました!
guest

回答1

0

ベストアンサー

CSSは弱いのですが,多分これですね

position: absolute; bottom: 3px; right: 3px;

absoluteですから親の<div class="Main__left__group">に対する位置になります。
全てのボタンが同じ位置に重なってるのでしょう。
loopの中全体を<div>で囲って見てください

投稿2020/06/22 08:18

winterboum

総合スコア23567

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

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

ko_no

2020/06/22 08:40

いただいた回答通りにしたところ綺麗さっぱり解決しました! 本当にありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問