Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How do I add a span in a link_to with an image

So I have this:

<%= link_to(image_tag(@model.picture.url(:thumb), :alt => ''), "/pages/you/#{something.id}", {:id => "y_link_#{something.id}"}) %>

Which works, but I need a span in between also like this:

 <a id="y_link_2" href="/pages/you/2" class="">
     <span>Apples</span>
     <img src="another_small.jpg?1236340989" alt="">
 </a>

How do I add

 <span>Apples</span>

to the link_to?

like image 730
Matt Elhotiby Avatar asked Jan 14 '11 04:01

Matt Elhotiby


3 Answers

For a path, use the structure like so

<%= link_to edit_section_path(@section) do %>
   Edit
   <span class="fa fa-list pull-right"></span>
<% end %>
like image 80
Sawo Cliff Avatar answered Oct 28 '22 15:10

Sawo Cliff


Feed a block to your link_to call:

<% link_to("/pages/you/#{something.id}", {:id => "y_link_#{something.id}"}) do %>
  <%= content_tag(:span, 'Apples') %>
  <%= image_tag(@model.picture.url(:thumb), :alt => '') %>
<% end %>

Alternatively:

<% link_to("/pages/you/#{something.id}", {:id => "y_link_#{something.id}"}) do %>
  <span>Apples</span>
  <%= image_tag(@model.picture.url(:thumb), :alt => '') %>
<% end %>
like image 18
Shaun Avatar answered Nov 13 '22 23:11

Shaun


image_tag and content_tag return basic strings, so they can be concatenated using the + operator easily:

<%= link_to(content_tag(:span, "Apples") + image_tag(@model.picture.url(:thumb), :alt => ''), "/pages/you/#{something.id}", {:id => "y_link_#{something.id}"}) %>

However, as you can see, it gets quite messy - might be worth moving it into a helper method.

like image 12
dnch Avatar answered Nov 13 '22 23:11

dnch