导致问题的表单:
<%= 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)
Like.find(post.user.likes)
正试图在给定likes
数组的情况下查找Like
。这真的没有多大意义。
很可能,您会想要搜索post.user.likes
,但即便如此,我还是有点困惑——您需要发布更多代码。
Like.find
正在查找id(整数)或包含键和值的哈希。数组不会提供任何可搜索的信息。
编辑:如果您正在寻找当前用户的点赞。您需要执行以下操作。。。
current_user.likes.where(:post => @post)
类型错误来自于将集合(post.user.likes
-这是一个数组)传递到需要记录id的方法中,例如Likes.find(3)
或Likes.find(params[:id])