Breadcrumb是导航元素,用于告诉用户他们在网站上的位置。
例如:
首页 >> 项目 >> 阶段 >> 上传。
其中首页、项目、阶段和上传都是不同的控制器。
Breadcrumb是导航元素,用于告诉用户他们在网站上的位置。
例如:
首页 >> 项目 >> 阶段 >> 上传。
其中首页、项目、阶段和上传都是不同的控制器。
我用了将近10年的时间几乎使用相同的代码... 最初是在ASP中编写的,然后是C#,PHP,现在是Rails:
module NavigationHelper
def ensure_navigation
@navigation ||= [ { :title => 'Home', :url => '/' } ]
end
def navigation_add(title, url)
ensure_navigation << { :title => title, :url => url }
end
def render_navigation
render :partial => 'shared/navigation', :locals => { :nav => ensure_navigation }
end
end
然后,在shared/navigation.html.erb
中:
<div class="history-nav">
<% nav.each do |n| %>
<%= link_to n[:title], n[:url] %>
<% end %>
<%= link_to yield(:title), request.path, :class => 'no-link' %>
</div>
你的常规视图:
<% content_for :title, 'My Page Title' %>
<% navigation_add 'My Parent Page Title', parent_page_path %>
而你的模板:
<html>
<head>
<title> <%= yield :title %> </title>
</head>
<body>
...
<%= render_navigation %>
...
<%= yield %>
</body>
</html>
在不使用<% content_for :title, 'My Page Title' %>
的情况下,可以更新先前的答案
<div class="history-nav">
<% nav.each do |n| %>
<% unless n.equal? nav.last %>
<%= link_to n[:title], n[:url] %>
<% else %>
<%= n[:title] %>
<% end %>
<% end %>
</div>