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

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

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

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

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

HTML

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

Q&A

0回答

794閲覧

検索ワードと一致するワード以外のものを、一致したワードの項目の下に表示をしたいが、そのやり方がわからない状態になっています。

avicii

総合スコア49

Ruby on Rails

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

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

HTML

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

0グッド

1クリップ

投稿2019/04/30 10:32

編集2019/05/01 08:51

・今現在、whereで検索した結果以外もviewで一致したワードの下に表示したいと考えています。しかし、そのやり方がわからない状態にいます。(コントローラのwhereの処理の後に、追加必要があると思うのですが、なにを加えればいいのかわからない状態にいます。)
・もしわかる方がいらしたら、教えて頂けたら、嬉しいです。

controller/plans_controller.rb

controller

1 def index 2 if Plan.find_by(title: params[:title]).blank? 3 @plans = Plan.includes(:guider).page(params[:page]).per(5).order("created_at DESC") 4 else 5 @plans = Plan.where(['title LIKE ?', "%#{params[:title]}%"]).page(params[:page]).per(5).order("created_at DESC") 6 end 7 end

view/index.html.erb

view

1 <div class="contents row"> 2 <% @plans.each do |plan| %> 3 <div class="content_post" style="background-image: url(<%= plan.image %>);"> 4 <div class="more"> 5 <span><%= image_tag 'arrow_top.png' %></span> 6 <ul class="more_list"> 7 <li> 8 <%= link_to 'detail', "/plans/#{plan.id}", method: :get %> 9 </li> 10 <% if guider_signed_in? && current_guider.id == plan.guider_id %> 11 <li> 12 <%= link_to '編集', "/plans/#{plan.id}/edit", method: :get %> 13 </li> 14 <li> 15 <%= link_to '削除', "/plans/#{plan.id}", method: :delete %> 16 </li> 17 <% end %> 18 </ul> 19 </div> 20 <%= simple_format(plan.title) %> 21 <span class="name"> 22 <a href="/guiders/<%= plan.guider_id %>"> 23 <span>guider</span><%= plan.guider.nickname %> 24 </a> 25 </span> 26 </div> 27 <% end %> 28 <%= paginate(@plans) %> 29</div>

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

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

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

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

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

m.ts10806

2019/04/30 12:00

not like は分かりますか?
avicii

2019/04/30 18:49

誠に申し訳ないです。知らないです。参考になるサイトとかあれば、教えていただけますか?
m.ts10806

2019/04/30 20:46

SQLのlikeの逆ですよ。検索すればすぐ出てきます。
avicii

2019/05/01 08:53 編集

もし、検索結果を一致した結果(最初に)と一致した結果以外(一致結果後)を表示したい場合は、このNot likeですることは可能ですか?(検索の処理とは別に、一致した結果の後に、全ての項目を載せたい場合)
m.ts10806

2019/05/01 08:58

like,not like別々で結果を取得する必要があります
avicii

2019/05/01 09:46

別々に結果を取得する場合は、どのような書き方ですればよろしいでしょうか?
m.ts10806

2019/05/01 10:30

別々で実行して別々で結果を得れば良いだけでは?まず書いてみてください。
avicii

2019/05/02 11:03 編集

controllerで @plans = Plan.where(['title LIKE ?', "%#{params[:title]}%"]).page(params[:page]).per(5).order("created_at DESC") @plan = Plan.where(['title NOT LIKE ?', "%#{params[:title]}%"]).page(params[:page]).per(5).order("created_at DESC")を追加して、 viewの@plans.each do |plan|の文の下に、@plan.each do |plan|を追加すればいいでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問