我确定我的问题很简单,我一直在寻找这个问题的答案,但我似乎无法让它发挥作用。我想做这样的事情:
<?xml version="1.0" encoding="UTF-8"?>
<configdata>
<dashboard>
<label>Dashboard</label>
<controller>dashboard</controller>
<action>index</action>
<module>global</module>
</dashboard>
<bills>
<label>Bills</label>
<pages>
<create-bill>
<label>Create New Bill</label>
<controller>bill</controller>
<action>create</action>
<module>global</module>
</create-bill>
</pages>
</bills>
</configdata>
请注意在<bills>
部分,我想要一个只有标签的类别,这样当我稍后添加样式时,我可以将鼠标悬停在“账单”和“创建新账单”上,其他链接将显示,但点击“账单”不应该做任何事情,因为它只是一个类别标题。
我希望这是有道理的。
最佳答案
您必须为您的页面指定类型,否则Zend_Navigation
将抛出异常。在像您这样的情况下,我总是使用 Zend_Navigation_Page_Uri
作为页面类型并将其 uri 指定为 #
。要将此应用于您的配置文件,您可以这样做
<bills>
<label>Bills</label>
<uri>#</uri>
<pages>
<create-bill>
<label>Create New Bill</label>
<controller>bill</controller>
<action>create</action>
<module>global</module>
</create-bill>
</pages>
</bills>
生成的标记仍然包含一个链接,但它不会指向任何地方。
此外,由于您需要将一些 javascript 绑定(bind)到它以显示菜单,您甚至可以通过在该链接的点击处理程序中返回 false
来禁用它。
为了将 javascript 回调(或某些 css)附加到那种链接,您可能会发现将类附加到这些链接很有用。在同一个配置文件中,您可以使用此代码
<bills>
<label>Bills</label>
<uri>#</uri>
<class>fakelink</class>
<pages>
<create-bill>
<label>Create New Bill</label>
<controller>bill</controller>
<action>create</action>
<module>global</module>
</create-bill>
</pages>
</bills>
在这种情况下,生成的标记将是
<li class="fakelink>
<a href="#">Bills</a>
<ul>submenu here</ul>
</li>
并且您可以使用 javascript 库轻松地选择那种链接。例如,对于 jQuery,您可以这样做:
$(function() { $('.fakelinks > a').click(function () { return false; }); });
关于php - 有没有办法在 zend 导航中有一个没有链接的导航条目?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6963417/