🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby on Rails

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

Q&A

解決済

2回答

360閲覧

railsのビューでもっときれいにかく方法はないか

shumbow

総合スコア35

Ruby on Rails

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

1グッド

3クリップ

投稿2019/10/25 17:00

erb

1 <div class="factors-box"> 2 <p><%= @article.factor1 %></p> 3 <p><%= @article.factor2 %></p> 4 <p><%= @article.factor3 %></p> 5 <p><%= @article.factor4 %></p> 6 <p><%= @article.factor5 %></p> 7 <% if @article.factor6.present? %> 8 <p><%= @article.factor6 %></p> 9 <% end %> 10 </div>

このように@articleがいくつか要素を持っていて、あれば出力、なければpタグごと消したいのですが、この例だと13まで入っていた場合、46のpタグは中身が空で残ってしまいます。これを放置するのはあまり良くないと思うので治したいです。一番下のだと期待通り動いたのですが、もうちょっとスマートにかく方法はありますか? if presented?などはやはり動きませんでした。

rails6
ruby 2.6.3

ryuii👍を押しています

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

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

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

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

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

guest

回答2

0

以下のようにselect文で@articleが空文字でないものを抽出して、each文でループさせて表示することができます。nilを表示させない場合は、selectの抽出条件を!item.nil?とします。

erb

1 2 <div class="factors-box"> 3 <% @article.select{|item| !item.empty? }.each do | factor | %> 4 <p><%= factor %></p> 5 <% end %> 6 </div> 7

投稿2019/10/25 22:03

編集2019/10/25 22:07
ryuii

総合スコア438

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

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

shumbow

2019/10/30 17:17

ありがとうございます。winterさんの別解とあわせて <% factors = [:factor1,:factor2,:factor3,:factor4, :factor5, :factor6].select{|factor| !@article.send(factor).empty? }%> <% factors.each do |factor| %> <p><%= @article.send(factor) %></p> <% end %> このように書いたらうまく動きました。今回のケースだと! empty?はなくても動きました!
guest

0

ベストアンサー

factor1〜6が methodやpropatyなのか、DBのcolumnにあるのかでやり方の選択幅が変わりますが(@article[:factor1] が使えるかどうか)

<% [:factor1,:factor2,:factor3,,,,].each do |factor| %> <% if @article.send(factor) %> <p><%= @article.send(factor) %></p> <% end %> <% end %> とか <% factors = [:factor1,:factor2,:factor3,,,,].select{|factor| @article.send(factor) }%> <% factors.each do |factor| %> <p><%= @article.send(factor) %></p> <% end %> とか 最初んところを <% factors = ("factor1".."factor6").select{|factor| @article.send(factor) } %> とか

投稿2019/10/25 23:40

winterboum

総合スコア23567

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

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

shumbow

2019/10/30 17:05

ありがとうございます!無事動きました。dbにあるカラムでプロパティだったのでシンボル名でうまくいきました。感謝します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問