更漂亮的 ERB 有条件地添加元素 class

Prettier ERB conditionally adding element class

我正在努力学习如何编写更漂亮的 ERB。我怎样才能格式化它看起来更漂亮?

<% site.data.navigation.each { |item| %>
  <a href="<%= item.link %>"
      <% if page.url == item.link %>class="current"<% end %>>
    <%= item.name %>
  </a>
<% } %>

特别是 class="current" 的环绕看起来很笨拙。我正在寻找不包含某些辅助方法的最佳方法。有没有更干净的东西?

我通过 ERB 做了很多 CSS 修改。我喜欢做这样的事情:

<% site.data.navigation.each { |item| %>
  <a href="<%= item.link %>" 
    class="<%= (page.url == item.link) ? 'current', '')%>" >
      <%= item.name %>
  </a>
<% } %>

虽然我尽量不让行越过我的编辑器屏幕的边缘,但 HTML 我并没有强制执行,因为我喜欢将标签视为一行:

 <% site.data.navigation.each do |item| %>
   <a href="<%= item.link %>" class="<%= (page.url == item.link) ? 'current', '')%>" >
      <%= item.name %>
   </a>
<% end %>

对我来说,它显示了外循环,然后是标签,然后是标签的内容,最后是结束标签。此外,我不使用 {} 进行多行循环。