我现在正在抓住所有用户. 但是,我想排除未确认的用户. 他们的confirmed_at属性为零. 我怎么能够? @search = User.search do fulltext params[:search] paginate :page = params[:page], :per_page = 10end @users = @se
但是,我想排除未确认的用户.
他们的confirmed_at属性为零.
我怎么能够?
@search = User.search do fulltext params[:search] paginate :page => params[:page], :per_page => 10 end @users = @search.results首先在您的用户模型中添加一个范围:
scope :confirmed, where("confirmed_at IS NOT NULL")
然后你只需要在搜索之前添加范围
@search = User.confirmed.search do fulltext params[:search] paginate :page => params[:page], :per_page => 10 end
编辑:
实际上,经过测试,上述解决方案似乎不起作用.范围似乎被忽略了.还有另一个解决方案:
在您的用户模型中,您可能有这样的方法:
searchable do text :lastname, :firstname ... end
您必须添加一个可搜索的条件:
searchable if: proc { |user| user.confirmed? } do text :lastname, :firstname ... end
编辑2:
如果有时您想要确认用户,有时甚至是所有用户,还有另一种方法,但您也需要修改模型.
在你的用户模型:
searchable do text :lastname, :firstname boolean :confirmed do confirmed_at != nil end ... end
然后在你的控制器中
@search = User.search do fulltext params[:search] with(:confirmed, true) # true if you want confirmed users, false for unconfirmed and if you want all users you don't write this line paginate :page => params[:page], :per_page => 10 end
我希望这有帮助