BootstrapBlazor实战 Menu 导航菜单使用(1)

实战BootstrapBlazorMenu 导航菜单的使用, 以及整合Freesql orm快速制作菜单项数据库后台维护页面

demo演示的是Sqlite驱动,FreeSql支持多种数据库,MySql/SqlServer/PostgreSQL/Oracle/Sqlite/Firebird/达梦/神通/人大金仓/翰高/华为GaussDB/MsAccess

1.Menu 导航菜单

为页面和功能提供导航的菜单列表。

@code{
 //演示数据
 private IEnumerable<MenuItem>? Items { get; set; } = new List<MenuItem>
            { 
                new MenuItem() { Text = "维保管理", Icon = "fa fa-address-book", Url = "/"  , Match = NavLinkMatch.All},
                new MenuItem() { Text = "车主", Icon = "fa fa-address-book", Url = "/owners" ,Items=new List<MenuItem>() {
                    new MenuItem() { Text = "车主列表", Icon = "fa fa-address-book", Url = "/owners"  , Match = NavLinkMatch.All},
                    new MenuItem() { Text = "车主添加", Icon = "fa fa-address-book", Url = "/owners/add"  , Match = NavLinkMatch.All},
                }},
                new MenuItem() { Text = "车辆", Icon = "fa fa-fw fa-car", Url = "/cars" },
                new MenuItem() { Text = "保险", Icon = "fa fa-fw fa-fa", Url = "/insurans"},
                new MenuItem() { Text = "出险记录", Icon = "fa fa-map-o", Url = "/insurancerecords"},
                new MenuItem() { Text = "花名册", Icon = "fa fa-fw fa-users", Url = "users" }
            };
}

顶栏

适用广泛的基础用法。

<Menu Items="@Items" DisableNavigation="true" OnClick="@OnClickMenu" />

@code{
 private Task OnClickMenu(MenuItem item)
    {
        System.Console.WriteLine($"菜单点击项: {item.Text}");
        return Task.CompletedTask;
    }
}

底栏

设置参数 IsBottom 值为 true 菜单栏在容器底部,适用移动端

<div style="height: 120px">
    <Menu Items="@Items" DisableNavigation="true" IsBottom="true" />
</div>

带图标的顶栏菜单

适用简单的网站应用,通过设置菜单项 MenuItem 的 Icon 属性设置菜单图标

new MenuItem() { Text = "维保管理", Icon = "fa fa-address-book"} 

侧栏

适用于左右结构布局的网站,通过设置 IsVertical 更改导航菜单为侧栏

<div style="width:220px; border-right: 1px solid #e6e6e6; padding-right: 4px;">
    <Menu Items="@Items" DisableNavigation="true" IsVertical="true" />
</div>

带图标的侧栏菜单

通过设置菜单项 MenuItem 的 Icon 属性设置菜单图标

<div style="width:220px;">
    <Menu Items="@Items" DisableNavigation="true" IsVertical="true" style="border-right: 1px solid #e6e6e6;" />
</div>

手风琴效果的侧栏

通过设置 IsAccordion 属性设置手风琴特效侧栏菜单

<div style="width:220px;">
    <Menu Items="@Items" DisableNavigation="true" IsVertical="true" IsAccordion="true" style="border-right: 1px solid #e6e6e6;" />
</div>

动态更改菜单

通过代码动态设置 Items 属性值更改菜单项

<div class="mt-3" style="width:220px;">
    <Menu Items="@DynamicSideMenuItems" DisableNavigation="true" IsVertical="true" style="border-right: 1px solid #e6e6e6;" />
</div>
<Button Text="更新菜单" OnClick="UpdateMenu" />
<Button Text="重置菜单" OnClick="ResetMenu" />

@code{

    private IEnumerable<MenuItem>? DynamicSideMenuItems { get; set; }

    private Task UpdateMenu()
    {
        DynamicSideMenuItems = new List<MenuItem>
            { 
                new MenuItem() { Text = "维保管理", Icon = "fa fa-address-book", Url = "/"  , Match = NavLinkMatch.All},
                new MenuItem() { Text = "车主", Icon = "fa fa-address-book", Url = "/owners" ,Items=new List<MenuItem>() {
                    new MenuItem() { Text = "车主列表", Icon = "fa fa-address-book", Url = "/owners"  , Match = NavLinkMatch.All},
                    new MenuItem() { Text = "车主添加", Icon = "fa fa-address-book", Url = "/owners/add"  , Match = NavLinkMatch.All},
                }}
            };
        return Task.CompletedTask;
    }

    private async Task ResetMenu()
    {
        DynamicSideMenuItems = new List<MenuItem>
            { 
                new MenuItem() { Text = "维保管理", Icon = "fa fa-address-book", Url = "/"  , Match = NavLinkMatch.All},
                new MenuItem() { Text = "保险", Icon = "fa fa-fw fa-fa", Url = "/insurans"},
                new MenuItem() { Text = "出险记录", Icon = "fa fa-map-o", Url = "/insurancerecords"},
                new MenuItem() { Text = "花名册", Icon = "fa fa-fw fa-users", Url = "users" }
            };
        return Task.CompletedTask;
    }
}

等等…

在这里篇幅有限不一一介绍,更多使用说明参考 https://www.blazor.zone/menus

Attributes 属性
参数
说明
类型
可选值
默认值
Items
菜单组件数据集合
IEnumerable<MenuItem>
IsVertical
是否为侧栏
bool
true|false
false
IsBottom
是否为底栏
bool
true|false
false
IsAccordion
是否手风琴效果
bool
true|false
false
DisableNavigation
是否禁止地址栏导航
bool
true|false
false
OnClick
菜单项被点击时回调此方法
Func<MenuItem, Task>

2. 下一篇为BootstrapBlazor实战 Freesql + MenuItem 控件使用

最近工作实在太忙了,本来还有好多计划要分享给大家的,等过几天闲暇下来,我再继续补上吧. :->

大佬和同学们有问题在文章后面留言,我都会一一尽力解答. 下一篇介绍整合Freesql orm 快速制作菜单项数据库后台维护页面

项目源码

Github | Gitee

关联项目

FreeSql QQ群:4336577(已满)、8578575(已满)、52508226(在线)

BA & Blazor QQ群:795206915、675147445

知识共享许可协议

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名AlexChow(包含链接: https://github.com/densen2014 ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我联系

AlexChow

今日头条 | 博客园 | 知乎 | Gitee | GitHub

### BootstrapBlazor Menu 组件实战使用示例 BootstrapBlazor 的 `Menu` 组件提供了强大的功能,用于创建垂直或水平的菜单栏,并支持动态绑定数据、手风琴效果等功能。以下是一个完整的实战示例,展示如何使用 `Menu` 组件并结合 C# 代码实现动态菜单的功能。 #### HTML 部分 在 Razor 文件中,可以定义一个简单的菜单结构如下: ```html <div style="width:220px;"> <Menu Items="@Items" DisableNavigation="true" IsVertical="true" IsAccordion="true" style="border-right: 1px solid #e6e6e6;" /> </div> ``` 此代码片段展示了如何通过设置 `IsAccordion` 属性为 `true` 来启用手风琴特效[^4]。 #### 后端逻辑部分 在对应的 C# 文件中,可以通过定义模型类来动态生成菜单项。以下是一个完整的代码示例: ```csharp using BootstrapBlazor.Components; using Microsoft.AspNetCore.Components; namespace BootstrapBlazor.Shared.Samples { public partial class MenuSample { private List<MenuItem> Items { get; set; } = new(); protected override void OnInitialized() { base.OnInitialized(); Items = new() { new MenuItem { Text = "首页", Url = "#" }, new MenuItem { Text = "关于我们", Url = "#about" }, new MenuItem { Text = "联系我们", Url = "#contact" }, new MenuItem { Text = "更多选项", Items = new() { new MenuItem { Text = "子菜单1", Url = "#submenu1" }, new MenuItem { Text = "子菜单2", Url = "#submenu2" } } } }; } } } ``` 在此代码中,`MenuItem` 是 `Menu` 组件的核心模型类,用于表示每个菜单项及其子菜单项[^5]。 #### 功能扩展 如果需要进一步扩展功能,例如动态更改菜单内容,可以通过事件绑定或服务注入的方式实现。例如,在某个按钮点击时更新菜单项列表: ```csharp private async Task UpdateMenu() { Items.Clear(); Items.Add(new MenuItem { Text = "更新后的首页", Url = "#" }); Items.Add(new MenuItem { Text = "更新后的关于我们", Url = "#updated-about" }); StateHasChanged(); // 触发界面刷新 } ``` ### 注意事项 - 确保在项目中已正确安装 `BootstrapBlazor` NuGet 包。 - 在 `_Imports.razor` 文件中添加命名空间引用:`@using BootstrapBlazor.Components`[^3]。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Densen2014

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值