如何列出喜欢给定帖子的用户

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何列出喜欢给定帖子的用户相关的知识,希望对你有一定的参考价值。

我无法弄清楚如何列出所有喜欢特定POST的用户。目前我正在使用:

<span class="count"><%= dailypost.likes.count %></span>

这允许我计算与该特定POST相关联的所有LIKES。但是它没有列出实际用户。

我已经尝试使用它来列出所有喜欢POST的用户

<%= dailypost.likes %>

相反,我回来了:

[#<Like id: 360, dailypost_id: 306, user_id: 1, created_at: "2013-04-28 21:51:45", updated_at: "2013-04-28 21:51:45">, 

#<Like id: 319, dailypost_id: 306, user_id: 104, created_at: "2013-04-28 19:27:35", updated_at: "2013-04-28 19:27:35">, 

#<Like id: 314, dailypost_id: 306, user_id: 103, created_at: "2013-04-28 19:24:19", updated_at: "2013-04-28 19:24:19">]

是否有人知道我如何能够提取用户列表或USER_ID?

RAILS新手请帮忙!!

楷模

class User < ActiveRecord::Base
  has_many :likes, dependent: :destroy
  has_many :dailyposts, dependent: :destroy
end

class Dailypost < ActiveRecord::Base
  belongs_to :user
  has_many :likes
end

class Like < ActiveRecord::Base
  belongs_to :user
  belongs_to :dailypost
end

数据库

ActiveRecord::Schema.define(:version => 20130210095553) do

create_table "dailyposts", :force => true do |t|
  t.string   "content"
  t.integer  "user_id"
  t.datetime "created_at",         :null => false
  t.datetime "updated_at",         :null => false
end

create_table "likes", :force => true do |t|
  t.integer  "dailypost_id"
  t.integer  "user_id"
  t.datetime "created_at",   :null => false
  t.datetime "updated_at",   :null => false
end

create_table "users", :force => true do |t|
  t.string   "name"
  t.string   "email"
  t.datetime "created_at",                                :null => false
  t.datetime "updated_at",                                :null => false
end

end

VIEWS

<span class="count"><%= dailypost.likes.count %></span>

<%= dailypost.likes %>

<span class="like">
 <% if like = current_user.likes.find_by_dailypost_id(dailypost.id) %>
   <%= form_for like, :html => { :method => :delete }, remote: true do |f| %>
     <span title="Unlike!"><%= image_submit_tag "Superman1.png" %></span>
   <% end %>
 <% else %>
 <%= form_for current_user.likes.build, remote: true do |f| %>
   <div><%= f.hidden_field :dailypost_id, value: dailypost.id %></div>
  <%= f.hidden_field :user_id %>
    <span title="Like!"><%= image_submit_tag "Superman2.png" %></span>
  <% end %>
 <% end %>
</span>
答案

最简单的理解方法是采取每个like,并要求它的user

dailypost.likes.map {|l| l.user}

当然,这会为每个like进行数据库查找,如果您有数百个用户,您可能希望避免这种情况。

因此,更复杂的方法是通过user_id执行单个查询以获取所有用户:

User.find(dailypost.likes.map {|l| l.user_id})

这将为您提供一个用户列表,这取决于您使用它做什么。如果您只想要HTML列表,请尝试以下方法:

<ul>
<% dailypost.likes.each do |l| %>
     <li> <%= link_to(l.user.name, l.user) %></li>
<% end %>
</ul>

这将依次查看每个like,然后询问其用户,然后询问用户的名称。

以上是关于如何列出喜欢给定帖子的用户的主要内容,如果未能解决你的问题,请参考以下文章

如何让用户在 Django 中只喜欢/不喜欢帖子一次?

如何使用 mongodb 和 mongoose 从帖子模型中计算整体帖子活动(喜欢、不喜欢、评论)和用户模型中的参考总和

如何使用 Firebase 存储喜欢

如何在 Parse 中存储喜欢帖子的人?

如何确定帖子是不是被 Mongoose 的用户点赞

仅在满足父模型的给定条件时如何获取模型关系