2

导致问题的形式:

<%= form_for Like.find(post.user.likes), :html => { :method => :delete , :class => "unlike_post_like_form" } do |f| %>

后模型

belongs_to :user
has_many :likes

用户模型

  has_many :posts
  has_many :likes

喜欢模型

  belongs_to :post
  belongs_to :user

我不断收到以下错误:

TypeError in Users#show 
Cannot visit Like

Like.find(post.user.likes),

编辑:

第一个解决方案:

改变

Like.find(post.user.likes),

Like.find(post.user.likes).limit(1),

第二种解决方案:

改变

Like.find(post.user.likes),

current_user.likes.where(:post_id => post.post_id)
4

2 回答 2

5

Like.find(post.user.likes)正在尝试查找Like给定的 . 数组likes。这真的没有多大意义。

很可能,您会想要搜索post.user.likes,但即便如此,我还是有点困惑——您需要发布更多代码。

Like.find正在寻找 id(整数)或包含键和值的散列。数组不给它任何搜索信息。

编辑:如果您正在寻找当前用户的喜欢。您需要执行以下操作...

current_user.likes.where(:post => @post)

于 2012-09-08T18:45:23.247 回答
1

例如,类型错误来自将集合(post.user.likes- 这是一个数组)传递给期望记录 id 的方法,Likes.find(3)或者Likes.find(params[:id])

于 2012-09-08T18:45:38.283 回答