7
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

gem gretel をslimを使って、詰まったちまったエラー

Last updated at Posted at 2017-10-28

gem gretel とは

  • パンくずを作成してくれる便利なgemです。

パンくず: 利用者がサイト内で現在に位置を見失わないようにするためのナビゲーションのようなものです。
(例)

スクリーンショット 2017-10-27 12.54.02.png

今回導入方法などは割愛させていただきます。
下記記事などを参考に、進めてみてください!

Ruby on Rails – パンくずリストを簡単に作成できるgem gretel
Ruby on Railsでパンくずリストを表示するGem gretelの使い方メモ

今回起きた事象

下記ファイルでパンくずを読み込む。

application.html.slim内

= breadcrumbs

index.html.slim内

- breadcrumb :watasan_campaign

すると、要素が表示するようになってしまう.......

スクリーンショット 2017-10-27 11.58.21.png

原因

リンクをつなげている  の文字にエスケープが行われている。

エスケープ: HTML文の中では「<」「>」>「&」「"」といった文字は特別な意味を持つため、HTMLタグを含む文字列をそのまま出力してしまうと違う意味になってしまう。したがって、特別の意味を持つ文字が含まれる文字列を文字列として出力されたい時には、特別な意味を持つ文字をエスケープした上で出力する必要があります

したがって
安全な文字列であるとして、特殊な文字もそのまま出力させる。
つまりエスケープさせないように表示させる必要がある。

application.html.slim

== breadcrumbs

==を使って表示させること!!
slimのREADMEに書いてありました。
https://github.com/slim-template/slim#output-without-html-escaping-

参考

gem lassebunk/gretel
gem slim-template/slim
Ruby on Rails – パンくずリストを簡単に作成できるgem gretel
Ruby on Railsでパンくずリストを表示するGem gretelの使い方メモ

7
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
7
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?