前提・実現したいこと
現在Ruby on Railsで簡単な検索機能を実装しているのですが、下の画像のように検索したワードと一致した文字を装飾するやり方が調べてもどうしてもわからなかっため、どのように実装できるか教えていただけませんか。
よろしくお願いいたします。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答2件
0
Ruby 又は Rails で検索して"Ruby on Rails(ルビーオンレイルズ)は、"という検索結果が得られ、の"Ruby" と”Rails"部分をふと文字にするとします。
rr=%w(Ruby Rails).map{|r| "(#{r})"}.join("|") reg=%r(#{rr}) "Ruby on Rails(ルビーオンレイルズ)は、".gsub(reg),"<em>\&</em>") # => "<em>Ruby</em> on <em>Rails</em>(ルビーオンレイルズ)は、"
なお、これをconsoleで試すときは \&
でなく \&
にしてください.
あ〜〜〜、円sainではなく逆スラッシュです。
投稿2020/07/16 13:09
総合スコア23567
0
ベストアンサー
Googleの検索結果では<em>検索キーワード</em>
としているようなのでそれに合わせます。
gsubで検索キーワードを任意のタグ(ここではem)で囲んでやって、cssで装飾すれば良いと思います。
ruby
1# 表示したい文字列 2text = 'Ruby on Rails(ルビーオンレイルズ)は、オープンソースのWebアプリケーションフレームワークである。RoRまたは単にRailsと呼ばれる。その名にも示されているようにRubyで書かれている。またModel View Controller(MVC)アーキテクチャに基づいて構築' 3 4# 検索キーワード 5keyword = 'Ruby on Rails' 6 7# 検索キーワードを<em></em>で囲む => 置換する 8text.gsub!(keyword, '<em class="search">' + keyword + '</em>') 9 10=> "<em class=\"search\">Ruby on Rails</em>(ルビーオンレイルズ)は、オープンソースのWebアプリケーションフレームワークである。RoRまたは単にRailsと呼ばれる。その 名にも示されているようにRubyで書かれている。またModel View Controller(MVC)アーキテクチャに基づいて構築"
- css
css
1em.search { 2 任意のスタイルを定義 3}
これを実際に使う場合は、ヘルパーにして使うと思います。
- app/helpers/application_helper.rb
ruby
1module ApplicationHelper 2 3 def decorate_keyword(text, keyword) 4 # 引数のtextを変化させないようにgsub!ではなく、gsubを使う 5 # HTMLタグがエスケープされないようにhtml_safeで返す 6 reuslt = text.gsub(keyword, '<em class="search">' + keyword + '</em>') 7 result.html_safe 8 end 9 10end
- 検索結果のビュー?
ruby
1<%= decorate_keyword("検索結果として表示する文字列", "検索キーワード") %>
投稿2020/07/16 12:49
編集2020/07/16 12:53総合スコア4207
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/07/18 09:34