如何在 current_page 上向 nav_link 添加更多元素?

Posted

技术标签:

【中文标题】如何在 current_page 上向 nav_link 添加更多元素?【英文标题】:How To add more element to nav_link on current_page? 【发布时间】:2012-12-25 15:35:57 【问题描述】:

我在导航菜单中有一些静态页面。我想为当前显示的项目添加更多元素。

在视图布局/adminzor.html.erb 上导航

<ul class='main-nav'>
    <%= nav_link 'Dashboard', adminzor_path %>
</ul>

关于 application_helper.rb

def nav_link(link_text, link_path)
  class_name = current_page?(link_path) ? 'active' : ''
    content_tag(:li, :class => class_name) do
      link_to link_text, link_path
    end
 end

和输出

<ul class='main-nav'>
   <li class="active">
      <a href="/adminzor">Dashboard</a>
   </li>
</ul>

因为我将 nav_link 助手与 Twitter Bootstrap 的 nav 组件一起使用,该组件更喜欢将链接包装在 li 标签内,并将“活动”类应用于外部 li。 我在视图上添加了一些元素,例如

<%= nav_link adminzor_path, :class => "light" do %>
  <div class="ico"><i class="icon-home icon-white"></i></div>
  Dashboard
<% end %>

和助手

def nav_link(link_text, link_path)
      class_name = current_page?(link_path) ? 'active' : ''
        content_tag(:li, :class => class_name) do
          link_to link_path do
           link_text
          end
        end
   end

但是错误

ArgumentError in Adminzor/dashboards#index

Showing c:/Sites/zionrails/app/views/layouts/adminzor.html.erb where line #44 raised:

wrong number of arguments (3 for 2)

我想输出比如

<ul class='main-nav'>
<li class="active">
 <a href="/adminzor" class="light">
    <div class="ico">
       <i class="icon-home icon-white"></i>
    </div>Dashboard
 </a>
</li>
</ul>

还有其他解决方案吗?谢谢

【问题讨论】:

【参考方案1】:
  def menu_link(link_text, icon_type, link_path)
    class_name = current_page?(link_path) ? 'active' : ''

    content_tag(:li, :class => class_name) do
      link_to link_path do
        content_tag(:i, '', :class => icon_type) + link_text
      end
    end

  end

然后打电话:

<%= menu_link('My lists', 'icon-list', user_lists_path(@user)) %>

【讨论】:

【参考方案2】:

已解决

application_helper.rb

def is_active?(link_path)
  if current_page?(link_path)
    "active"
  else
    ""
  end
end

在 layout/adminzor.html.erb 上如

<li class="<%= is_active?(adminzor_path) %>">
                <%= link_to adminzor_path, :class => 'light' do %>
                <div class="ico"><i class="icon-home icon-white"></i></div>
                Dashboard
                <% end %>
</li>

【讨论】:

以上是关于如何在 current_page 上向 nav_link 添加更多元素?的主要内容,如果未能解决你的问题,请参考以下文章

如何在android上向manageQuery添加限制子句

如何在 Android 上向用户付款

如何在 DiscordJS v13 上向用户添加角色?

VSCode - 光标在 AltGr 上向左移动。如何解决?

如何在 HHVM 上向浏览器输出/显示致命错误

如何在 iOS 设备上向 Web 应用程序发送推送通知?