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

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

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

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

Ruby

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

Ruby on Rails

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

Q&A

解決済

1回答

1689閲覧

Rails5でplaceholderにfont-awesomeのiconをいれたい

hatsu

総合スコア1809

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

Ruby

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

Ruby on Rails

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

1グッド

0クリップ

投稿2017/10/26 15:20

編集2017/10/27 00:36

現在ruby2.4.0、rails5で

ruby

1 <%= form_tag pages_search_path, :method => 'get' do %> 2 <div class="input-group"> 3 <%= text_field_tag :search, params[:search], class: 'form-control font-awesome', placeholder: '&#xF002 ruby',id: "inlineFormInputGroup2" %> 4 <%= submit_tag "検索",class: 'input-group-addon search_button' %> 5 </div> 6 <% end %>

css

1.font-awesome{ 2 font-family: FontAwesome; 3 font-style: normal; 4 font-weight: normal; 5 text-decoration: inherit; 6}

と書いています。本来なら表示がされると思うのですが、
なぜか表示がされません。

イメージ説明

書き方はあっていると認識していており、表示がされない理由とその解決策を教えていただけると幸いです。
そのほか必要な情報があれば、追記していきますので質問、回答をお願いいたします。

gouf👍を押しています

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

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

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

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

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

gouf

2017/10/26 23:45

質問タグ、Rails のタグが抜けているので追加をお願いします
guest

回答1

0

ベストアンサー

Font Awesome などの、アイコンを文字として表示するライブラリは、そのデータの実体としてUnicode 文字が使用されています

それぞれ、HTML 周りでは &, ; でのセット、Ruby 周りでは先頭に \u を付けて指定する、という違いがあります

そのため、「HTML 側のルール」を「Ruby 側のルール」で解釈した場合に、単なる文字列として処理されてしまっているのかもしれません

Ruby 側で利用する際には、参照指定を &#xF002;\uF002 と読み替える必要がありそうです

erb

1<%= text_field_tag :search, params[:search], class: 'form-control fa', placeholder: "\uF002" %>

試したこと

Font Awesome のアイコン文字を表示できた例:

  • レンダリングエンジン側(Slim)で出力(クラス名指定、参照文字記述)

slim

1p.fa &#xF002;
  • &#xF002; をRuby 側の参照ルールに合わせる、それを直接出力(クラス名指定)

slim

1p.fa = "\uF002"
  • &#xF002; をRuby 側の参照ルールに合わせる、オプションでそれを指定(クラス名指定, Rails のタグ生成メソッド)

slim

1= content_tag(:input, '', class: 'form-control empty', placeholder: "\uF002" + 'foo bar') 2= text_field_tag :search, params[:search], class: 'form-control fa', placeholder: "\uF002
  • &#xF002; が参照している文字の実体をオプションに直接貼り付け(クラス名指定、Rails のタグ生成メソッド)

slim

1= text_field_tag :search, params[:search], class: 'form-control fa', placeholder: ''
  • &#xF002; が参照している文字の実体を直接貼り付け、レンダリングエンジン(Slim)に出力させる(クラス名指定)

slim

1p.fa 

かなり泥臭い調べ方をしてしまいましたが、何か参考になれば幸いです

Links

投稿2017/10/26 23:44

編集2017/10/26 23:47
gouf

総合スコア2321

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

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

hatsu

2017/10/27 03:12

gouf様 ご回答ありがとうございます。 <%= text_field_tag :search, params[:search], class: 'form-control font-awesome fa', placeholder: "\uF002 ruby",id: "inlineFormInputGroup2" %> と、 &#x→\uとし、シングルクオテーションからダブルクオテーションに変更することでserachiconが正しく表示されました。 ずっとつまづいていたので、大変ありがたいです。 誠にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問