从ruby控制器有条件地设置CSS样式

Pro*_*ero 7 css ruby haml ruby-on-rails

我正在尝试动态更改(如果它被点击)一个正常的表头(这是一个链接)到另一个定义的CSS类'th.hilite'.此链接只是对此列进行排序,并且每次用户对列表进行排序时都应突出显示标题.

应该更改有问题的类的视图如下所示:

%table#mytable
  %thead
    %tr
      %th= link_to 'Title', mytable_path(:sort => 'title'), :id => 'title_header'
Run Code Online (Sandbox Code Playgroud)

我的问题很简单:如果单击标题,我可以如何以及在何处将类动态设置为%th.hilite?

Szi*_*zsi 26

您可以直接从视图中绑定它:

%th{:class => ("hilite" if @sort == "title")}= link_to 'Movie Title'...

但是,您还必须@sort在控制器中声明实例变量,并根据要排序的列将其设置为标题发布.(即@sort = params[:sort])

  • 实际上你不必声明一个实例变量,你可以简单地使用params [:sort] (3认同)

meh*_*guh 14

如果能找到解决方法,请注意不要在视图中放置逻辑(偶数条件).为了避免这种常见错误,您需要充分利用参数和会话哈希并在控制器中设置适当的变量

# In your view
%th{:class => @title_header}= link_to 'Title', my_path(:sort => 'title'), :id => 'title_header'

# In your controller
sort = params[:sort] || session[:sort]
if sort == 'title'
  ordering = {:order => :title}
end
Run Code Online (Sandbox Code Playgroud)