Responding with js in Rails

2019-09-10 08:36发布

We have a link_to sending an ajax post, and are wondering if there's a way to change the content of the sending tag.

We basically want to update the database, then change the icon in the link_to block.

 <%= link_to add_favorite_path({type: type, id: id}), 
      type:"button", disable_with: '...', :method => :post, 
      :remote => true, class: 'btn btn-default btn-sm', id: "#{type}-#{id}" do %>
      <i class="fa fa-plus"></i>
<% end %>

Here's the favorites contoller:

class FavoritesController < ApplicationController
    respond_to :js

    def add
        @type = params[:type]
        @id     = params[:id]
        @selector = "#{@type}-#{@id}"    
    end
end

EDIT: add.js.erb:

var link = $("a#<%= @selector %>");
link.html('<i class="fa fa-check"></i>');

Found Solution: Could not alter the item html when using the disable_with: option. Removed it and it works.

1条回答
劳资没心,怎么记你
2楼-- · 2019-09-10 09:01

You can just make sure the appropriate controller reponds to JS

respond_to :js, :html

Then create the view file add.js.erb to add the appropriate JS to render the new icon. I would like to see more code but something like this

$("#id_of_link").html("<i class='fa fa-check'></i>");

Although, I usually create partials and escape_javascript to render the new partial in the JS

查看更多
登录 后发表回答