1

我正在用 C# 以编程方式构建一个 ASP.Net 4.5 菜单。顶部菜单项的格式符合我的喜好,但子项不会继承该格式。我最关心的格式有两件事:StaticEnableDefaultPopOutImage,它控制那个小箭头是否显示在 MenuItem 旁边,以及 ItemSpacing。前者在 asp:Menu 定义中设置为 false 并且适用于顶部菜单项(即,不显示小箭头),但不适用于子项(小箭头确实显示在子项旁边) . 后者设置为 75 像素,顶部菜单项之间的间距很好。但是,子项和它们的子项是挤在一起的。我不确定如何控制这种行为。最后,菜单在母版页中定义。这是我在 Master 中的菜单代码:

<asp:Menu runat="server" CssClass="bgcell_top_nav" ID="menuMain" Orientation="Horizontal" RenderingMode="Table" StaticEnableDefaultPopOutImage="false" Width="100%" ItemWrap="false" Height="250" DynamicVerticalOffset="8" StaticDisplayLevels="1">
    <StaticMenuItemStyle ItemSpacing="75px" />
</asp:Menu>

这是我背后的代码:

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        //top menu items
        MenuItem ApplicationFunctionality = new MenuItem();
        ApplicationFunctionality.Text = "Applications";
        ApplicationFunctionality.SeparatorImageUrl = "~/images/menu-pipe.png";
        this.menuMain.Items.Add(ApplicationFunctionality);
        MenuItem DatabaseFunctionality = new MenuItem();
        DatabaseFunctionality.Text = "Databases";
        DatabaseFunctionality.SeparatorImageUrl = "~/images/menu-pipe.png";
        this.menuMain.Items.Add(DatabaseFunctionality);

        //sub menu items
        MenuItem Application_Add = new MenuItem();
        Application_Add.Text = "Add";
        ApplicationFunctionality.ChildItems.Add(Application_Add);
        MenuItem Application_Search = new MenuItem();
        Application_Search.Text = "Search";
        ApplicationFunctionality.ChildItems.Add(Application_Search);
        MenuItem Application_Reports = new MenuItem();
        Application_Reports.Text = "Reports";
        ApplicationFunctionality.ChildItems.Add(Application_Reports);

        MenuItem CreateInternalApplication = new MenuItem();
        CreateInternalApplication.Text = "Internal";
        CreateInternalApplication.NavigateUrl = "~/TemplateForms/ApplicationCreationTemplateForm.aspx";
        Application_Add.ChildItems.Add(CreateInternalApplication);
        MenuItem CreateExternalApplication = new MenuItem();
        CreateExternalApplication.Text = "External";
        Application_Add.ChildItems.Add(CreateExternalApplication);
    }
}

我附上了一张照片,这样人们就可以看到我在说什么问题。

在此处输入图像描述

非常感谢有关如何格式化子项目的任何指导。

4

1 回答 1

0

删除箭头图标:

问题是StaticEnableDefaultPopOutImage="false"仅适用于静态菜单级别,并且您拥有StaticDisplayLevels="1". 其他两个级别是动态的,因此您还需要DynamicEnableDefaultPopOutImage="false".

添加间距:

要为动态级别添加间距,您可以使用:

<DynamicMenuItemStyle ItemSpacing="75px" />

应用自定义样式:

或者,可以将自定义样式应用于每个菜单级别。这将使您更好地控制菜单的外观。在您的菜单中,使用 . 声明菜单项级别的样式LevelMenuItemStyles。例如,在这里我为前 3 个菜单项级别添加样式类:

<asp:Menu runat="server" CssClass="bgcell_top_nav" 
        ID="menuMain" Orientation="Horizontal" RenderingMode="Table"
        StaticEnableDefaultPopOutImage="false" Width="100%"
        ItemWrap="false" Height="250" DynamicVerticalOffset="8"
        StaticDisplayLevels="1">
    <LevelMenuItemStyles>
        <asp:MenuItemStyle CssClass="menuItemLevel1"/>
        <asp:MenuItemStyle CssClass="menuItemLevel2"/>
        <asp:MenuItemStyle CssClass="menuItemLevel3" />
    </LevelMenuItemStyles> 
</asp:Menu>

然后您应该能够自定义菜单的项目级别样式,例如

.menuItemLevel2{
    margin-left:7px;
}
.menuItemLevel3{
    margin-left:12px;
}
于 2018-04-28T11:46:31.410 回答