Just wondering whether there\'s a way to use turbolinks directly in a rails link_to helper, a quick bit of googling didn\'t uncover anything of note, here\'s the type of thi
Or Ruby 1.9+ syntax:
<%= link_to 'Foo', foo_path(@foo), data: { no_turbolink: true } %>
But I ended up dropping turbolinks in favour of Wiselinks which makes behaviour explicit on all links, plus Wiselinks also supports partial update (eg paging), replace state (doesn't pollute browser history, great for column sorting), form submission (great for search forms), redirects, support for browsers without history API, and more intelligent asset change handling.
@Joseph you are right, but only small change:
<%= link_to "Foo", new_foo_path(@foo), data: { turbolinks: 'false' } %>
when I'm typing turbolinks: false
doesn't work with bool, works only when I use string for value turbolinks: 'false'
. So maybe someone help this information ;).
Turbolinks 5 uses a slightly different syntax
<%= link_to "Foo", new_foo_path(@foo), data: { turbolinks: false } %>
Source: Turbolinks Github Page
You can use a symbol without problems to generate the following code:
<a data-no-turbolink='true' href="/giraffe-130">Giraffe</a>
Just do the following:
<%= link_to 'Giraffe', giraffe_path(@giraffe),
:data => { :no_turbolink => true } %>
Note: :no_turbolink
will become no-turbolink
and the value will be converted to JSON automatically using to_json
, e.g. true
to "true"
.
when you'd like to change language using locale, you have do like here:
<%= link_to content_tag(:span, "Українською"), {locale: :uk},
data:{ turbolinks: "false" }%>
Edit for Rails 5+: @ManishShrivastava correctly pointed out the different syntax needed for Rails 5 as shown in Joseph's answer.
<%= link_to('Giraffe', @giraffe, data: { turbolinks: false }) %>
For Rails 4 and below
Originally I thought you needed to use the hash rocket syntax for the symbol but that isn't the case. You can use a data:
hash and inside that hash any symbols using underscores _
will be converted to dashes -
.
I think most Rails developers would prefer to see the following (including myself now that I know better):
<%= link_to('Giraffe', @giraffe, data: { no_turbolink: true }) %>
But the following also works:
<%= link_to('Giraffe', @giraffe, 'data-no-turbolink' => true) %>