I'm trying to render a link preceded by an icon. I'm using Slim templating engine along with Bootstrap CSS.
Usually you could do this the following way:
<a href="#"><i class="icon-user"></i> My Profile</a>
According to Slim's documentation, we can use ==
to render without escaping HTML. So, translating this to Slim, I tried the following variations:
li== link_to "<i class='icon-user'></i> My Profile", current_user
li== link_to "#{'<i class="icon-user"></i>'.html_safe} My Profile", current_user
li= link_to "#{'<i class="icon-user"></i>'.html_safe} My Profile", current_user
All variations rendered <a href="/users/1"><i class="icon-user"></i> My Profile</a>
escaping the i
tag.
How can I stop Slim or Rails from escaping html?
(Rails 3.2 with Slim 1.2.1)
This has been answered, but if you actually have some html and you want to render it in a slim template, use double equal.
Will be the same as
Alternatively, you could write this as
which arguably is a little easier to read.
You want to disable HTML escaping for the
link_to
argument, not the entirelink_to
result. You're pretty close with yourhtml_safe
but your string interpolation is eating your "safe for HTML" flag. This should work better:There's another way of tackling this below in case it helps anyone. Using a block is especially useful if you have more complex code to include within the link.