3

我对作为可投票的行为有一点问题。

我的“喜欢”按钮和计数在我的每个“软件”页面上正确刷新(使用 AJAX)。但是在主页上不能正常工作(或者有几个软件)。

当我点击一个赞按钮(在我的主页上)时,赞计数会更新,但值会更新,并且对于所有软件都是相同的(但是当我手动刷新页面时,值是正确的)。

我找不到这个问题的解决方案。

我的代码:

softwares_controller.rb

 def upvote
    if !current_user.liked? @software
      @software.liked_by current_user
    elsif current_user.liked? @software
      @software.unliked_by current_user 
    end
    respond_to do |format|
        format.html { redirect_back(fallback_location: root_path) }
        format.js 
        end
  end 

软件/节目

<%= link_to like_software_path(@software), class:"like-btn", method: :put, remote: true do %> 
    <button class="btn btn-warning"> 
      <span><p><i class="fa fa-thumbs-up fa-lg" aria-hidden="true"></i></p></span>
    </button> 
<% end %>
<span class="likes-count"> <%= @software.get_upvotes.size %> </span> 

主页视图

<%= link_to like_software_path(software), class:"like-btn", method: :put, remote: true do %> 
    <button class="btn btn-warning"> 
      <span><p><i class="fa fa-thumbs-up fa-lg" aria-hidden="true"></i></p></span>
    </button> 
<% end %>
<span class="likes-count"> <%= software.get_upvotes.size %> </span>  

路线.rb

resources :softwares do
  member do
    put "like" => "softwares#upvote"
    put "dislike" => "softwares#downvote"
  end
end

软件/upvotes.js.erb

<% if current_user.liked? @software %>
   $(".likes-btn").addClass("liked");
<% else %>
   $(".likes-btn").removeClass("liked");
<% end %>
   $(".likes-count").addClass("liked").html('<%= @software.get_upvotes.size %>');

编辑:或者当我更改我的主页时:

<%= link_to like_software_path(@software), class:"like-btn", method: :put, remote: true do %> 
    <button class="btn btn-warning"> 
      <span><p><i class="fa fa-thumbs-up fa-lg" aria-hidden="true"></i></p></span>
    </button> 
<% end %>
<span class="likes-count"> <%= @software.get_upvotes.size %> </span> 

我有一个错误:

No route matches {:action=>"upvote", :controller=>"softwares", :id=>nil}, missing required keys: [:id]
4

1 回答 1

3

这一行:

$(".likes-count").addClass("liked").html('<%= @software.get_upvotes.size %>');

.likes-count正在使用该类更新所有元素的显示投​​票计数值。要解决此问题,请更改:

<span class="likes-count"> <%= software.get_upvotes.size %> </span>

包括该id软件,并将其定位在您的 js 中。

<span class="likes-count" id="software-<%= software.id %>">
  <%= software.get_upvotes.size %>
</span>

软件/upvotes.js.erb

$("#software-<%= @software.id %>").addClass("liked").html('<%= @software.get_upvotes.size %>');
于 2018-06-05T21:14:34.133 回答