我希望使用ASP.NET菜单控件来浏览我的网站。但是,我要求每个MenuItem必须设置不同的样式(不同的颜色,静态和onHover)。如果不创建从MenuItem继承的自定义类,这可能吗?
关于更好解决方案的想法?
答案 0 :(得分:13)
如果有人碰到同样的问题......
一个对我有用的快速而简单的方法是将HTML内容强制进入MenuItem Text
(通过适当的转义)。然后,您可以在CSS中以任何方式设置样式,甚至可以将每个菜单项设置为使用不同的样式:
<asp:MenuItem Text="<span class="menuitem_text">Text Here</span>" />
HTML最终位于<a>
标记内:
<li><a ...><span class="menuitem_text">Text Here</span></a></li>
答案 1 :(得分:11)
如果没有在菜单上覆盖RenderContents,那么您的选项非常有限。你所需要的大多数是私密的和密封的,你不会在那里的任何地方。
我的解决方案是使用模板。您可以使用MenuItem.Value或Depth和ItemIndex来标识每个项目并提供必要的属性。
在Page:
<asp:Menu ID="menu" runat="server" DynamicHorizontalOffset="2" StaticSubMenuIndent="10px">
<Items>
<asp:MenuItem Text="Item 1" Value="value 1">
<asp:MenuItem Text="Item 2" Value="value 2">
<asp:MenuItem Text="Item 3" Value="value 3"></asp:MenuItem>
</asp:MenuItem>
<asp:MenuItem Text="Item 4" Value="value 4">
<asp:MenuItem Text="Item 5" Value="value 5"></asp:MenuItem>
</asp:MenuItem>
<asp:MenuItem Text="Item 6" Value="value 6"></asp:MenuItem>
</asp:MenuItem>
<asp:MenuItem Text="Item 7" Value="value 7"></asp:MenuItem>
<asp:MenuItem Text="Item 8" Value="value 8"></asp:MenuItem>
</Items>
<StaticItemTemplate>
<asp:Panel runat="server" ForeColor='<%# GetItemColor(Container) %>'>
<%# Eval("Text") %> - <%# Eval("Value") %>
</asp:Panel>
</StaticItemTemplate>
<DynamicItemTemplate>
<asp:Panel ID="Panel1" runat="server" ForeColor='<%# GetItemColor(Container) %>'>
<%# Eval("Text") %> - <%# Eval("Value") %>
</asp:Panel>
</DynamicItemTemplate>
</asp:Menu>
在Code中(不要忘记这段代码的愚蠢,只是为了证明原理):
public Color GetItemColor(MenuItemTemplateContainer container)
{
MenuItem item = (MenuItem)container.DataItem;
//identify based value
if (item.Value == "value 2")
return Color.Brown;
//identify based on depth and index
if (item.Depth == 0)
switch (container.ItemIndex)
{
case 0: return Color.Red;
case 1: return Color.Blue;
case 2: return Color.DarkGreen;
default:
return Color.Black;
}
else
switch (container.ItemIndex)
{
case 0: return Color.Purple;
case 1: return Color.Aqua;
case 2: return Color.DarkOrange;
default:
return Color.Black;
}
}
答案 2 :(得分:0)
尝试这样设置每个菜单项的样式:
代码背后:
mnuMail.Items[1].Text = "<span class=\"bold\">Inbox</span>";
CSS课程:
.bold
{
font-weight: bold;
}
答案 3 :(得分:-3)
如果以编程方式生成菜单,则可以在创建每个MenuItem时添加样式和onmouseover / onmouseout属性,例如:
menuItem.Attributes["style"] = "color: red;";
menuItem.Attributes["onmouseover"] = "javascript:Highlight(this);";
或者,尝试在标记中添加这些属性,IntelliSense不会告诉您它们有效,但它们通常会这样做(我没有使用MenuItems专门测试它):
<asp:menuitem navigateurl="Home.aspx"
text="Home"
imageurl="Images\Home.gif"
popoutimageurl="Images\Popout.jpg"
tooltip="Home"
style="color: red;" onmouseover="Highlight(this);" onmouseout="Unhighlight(this);"/>
CSS Friendly Adapters可能会有运气。
当然,您可以创建一个继承的类并重新处理渲染例程...