10

我是 nanoc 的新手,我仍然在它周围找到我的。我能够准备好我的网站,它看起来不错,功能也很好。但我需要有一个标签区域。我能够做到这一点

<%= tags_for(post, params = {:base_url => "http://example.com/tag/"}) %>

但是如何为标签生成页面?因此,例如有一个名为“NFL”的标签,因此每次用户点击它时,他/她都应该被引导到http://example.com/tag/nfl与 NFL 对应的文章列表。

我可以设置一个布局来做到这一点。但是那我应该使用什么样的逻辑呢?而且我还需要一个帮手吗?

4

1 回答 1

21

您可以在Rules文件中使用预处理块来动态生成新项目。这是一个预处理块的示例,其中添加了一个新项目:

preprocess do
  items << Nanoc::Item.new(
    "some content here",
    { :attributes => 'here', :awesomeness => 5000 },
    "/identifier/of/this/item")
end

如果您想要每个标签的页面,您需要先收集所有标签。我这样做是因为我不想重复:

require 'set'
tags = Set.new
items.each do |item|
  item[:tags].each { |t| tags.add(t.downcase) }
end

最后,遍历所有标签并为它们生成项目:

tags.each do |tag|
  items << Nanoc::Item.new(
    "",
    { :tag => tag },
    "/tags/#{tag}/")
end

现在,您可以为 /tags/*/ 创建一个特定的编译规则,以便使用“tags”布局呈现它,该布局将采用 :tag 属性的值,查找具有此标记的所有项目并将它们显示在列表。该布局看起来有点像这样:

<h1><%= @item[:tag] %></h1>
<ul>
  <% items_with_tag(@item[:tag]).each do |i| %>
    <li><%= link_to i[:title], i %></li>
  <% end %>
</ul>

概括地说,这应该是你想要的!

于 2012-12-14T05:32:20.563 回答