abp(net core)+easyui+efcore實現倉儲管理系統——ABP整體介紹(一)html
abp(net core)+easyui+efcore實現倉儲管理系統——解決方案介紹(二)數據庫
abp(net core)+easyui+efcore實現倉儲管理系統——領域層建立實體(三)app
abp(net core)+easyui+efcore實現倉儲管理系統——定義倉儲並實現 (四)框架
abp(net core)+easyui+efcore實現倉儲管理系統——建立應用服務(五)ide
abp(net core)+easyui+efcore實現倉儲管理系統——展示層實現增刪改查之控制器(六)函數
abp(net core)+easyui+efcore實現倉儲管理系統——展示層實現增刪改查之列表視圖(七)post
abp(net core)+easyui+efcore實現倉儲管理系統——展示層實現增刪改查之增刪改視圖(八)測試
abp(net core)+easyui+efcore實現倉儲管理系統——展示層實現增刪改查之菜單與測試(九)ui
abp(net core)+easyui+efcore實現倉儲管理系統——多語言(十)this
abp(net core)+easyui+efcore實現倉儲管理系統——使用 WEBAPI實現CURD (十一)
abp(net core)+easyui+efcore實現倉儲管理系統——使用 WEBAPI實現CURD (十二)
abp(net core)+easyui+efcore實現倉儲管理系統——使用 WEBAPI實現CURD (十三)
abp(net core)+easyui+efcore實現倉儲管理系統——使用 WEBAPI實現CURD (十四)
abp(net core)+easyui+efcore實現倉儲管理系統——使用 WEBAPI實現CURD (十五)
在前面的文章(abp(net core)+easyui+efcore實現倉儲管理系統——展示層實現增刪改查之菜單與測試(九) )中咱們學會了如何添加靜態菜單,可是作爲一個信息管理系統,總不能每次有新功能新菜單,都靜態添加菜單,編譯,再上線。咱們但願的是有一個菜單管理界面,在此頁面中輸入相應的菜單,只要咱們從新登陸,菜單就自動顯示在菜單欄中。而菜單的來源能夠是多樣的,能夠從須要從數據庫,xml等數據源中加載一些動態菜單來知足咱們的系統要求。
今天咱們就來實現這個功能,動態加載菜單。所要加載的菜單就是模塊管理中的功能模塊。
一個應用程序可能包含不一樣的模塊,而每一個模塊均可能有它本身的菜單項。在Abp中,須要建立一個派生自NavigationProvider的類來定義一個菜單項。例如咱們這個項目中的TPLMSNavigationProvider類。代碼以下。
using Abp.Application.Navigation; using Abp.Localization; using ABP.TPLMS.Authorization; namespace ABP.TPLMS.Web.Startup { /// <summary> /// This class defines menus for the application. /// </summary> public class TPLMSNavigationProvider : NavigationProvider { public override void SetNavigation(INavigationProviderContext context) { context.Manager.MainMenu .AddItem( new MenuItemDefinition( PageNames.Home, L("HomePage"), url: "", icon: "home", requiresAuthentication: true ) ).AddItem( new MenuItemDefinition( PageNames.Tenants, L("Tenants"), url: "Tenants", icon: "business", requiredPermissionName: PermissionNames.Pages_Tenants ) ).AddItem( new MenuItemDefinition( PageNames.Users, L("Users"), url: "Users", icon: "people", requiredPermissionName: PermissionNames.Pages_Users ) ).AddItem( new MenuItemDefinition( PageNames.Roles, L("Roles"), url: "Roles", icon: "local_offer", requiredPermissionName: PermissionNames.Pages_Roles ) ) .AddItem( new MenuItemDefinition( PageNames.Module, L("Module"), url: "Module", icon: "local_offer" ) ) .AddItem( new MenuItemDefinition( PageNames.Supplier, L("Supplier"), url: "Supplier", icon: "people" ) ) .AddItem( new MenuItemDefinition( PageNames.About, L("About"), url: "About", icon: "info" ) ).AddItem( // Menu items below is just for demonstration! new MenuItemDefinition( "MultiLevelMenu", L("MultiLevelMenu"), icon: "menu" ).AddItem( new MenuItemDefinition( "AspNetBoilerplate", new FixedLocalizableString("ASP.NET Boilerplate") ).AddItem( new MenuItemDefinition( "AspNetZero", new FixedLocalizableString("ASP.NET Zero") ).AddItem( new MenuItemDefinition( "AspNetZeroHome", new FixedLocalizableString("Home"), url: "https://aspnetzero.com?ref=abptmpl" ) ).AddItem( new MenuItemDefinition( "AspNetZeroDocuments", new FixedLocalizableString("Documents"), url: "https://aspnetzero.com/Documents?ref=abptmpl" ) ) ) ); } private static ILocalizableString L(string name) { return new LocalizableString(name, TPLMSConsts.LocalizationSourceName); } } }
2、abp菜單類
ABP框架中已經爲咱們作了前期的準備工做。在ABP中有一個MenuDefinition類,這個類封裝了導航欄上的主菜單的屬性。
MenuDefinition:主菜單類,定義了一個List<MenuItemDefinition>,這個類存放了咱們定義的菜單,同時定義了AddItem方法
using System.Collections.Generic; using Abp.Localization; namespace Abp.Application.Navigation { // Represents a navigation menu for an application. public class MenuDefinition : IHasMenuItemDefinitions { // // 構造函數 // public MenuDefinition(string name, ILocalizableString displayName, object customData = null); // //菜單名稱 // public string Name { get; } // //表示本地化字符串 // public ILocalizableString DisplayName { get; set; } // //自定義數據 // public object CustomData { get; set; } // 菜單集合 public List<MenuItemDefinition> Items { get; set; } // 添加菜單 // public MenuDefinition AddItem(MenuItemDefinition menuItem); // // 刪除菜單 // public void RemoveItem(string name); } }
在ABP中還有一個MenuItemDefinition類,這個類中封裝了子菜單的屬性,子菜單能夠添加其餘子菜單構成一個菜單樹。咱們首先來了解一下MenuItemDefinition類的屬性與方法。MenuItemDefinition成員定義以下:
public class MenuItemDefinition : IHasMenuItemDefinitions { // // 構造函數: public MenuItemDefinition(string name, ILocalizableString displayName, string icon = null, string url = null,
bool requiresAuthentication = false, string requiredPermissionName = null, int order = 0, object customData = null,
IFeatureDependency featureDependency = null, string target = null, bool isEnabled = true, bool isVisible = true,
IPermissionDependency permissionDependency = null); // // 摘要: // Can be used to enable/disable a menu item. public bool IsEnabled { get; set; } // 自定義數據 public object CustomData { get; set; } // // 摘要: // Target of the menu item. Can be "_blank", "_self", "_parent", "_top" or a frame // name. public string Target { get; set; } // 是否有子菜單 public bool IsLeaf { get; } // 權限驗證若是經過驗證顯示此菜單不然不可見 //即只有登錄後纔會顯示該菜單 public bool RequiresAuthentication { get; set; } // 功能特性 public IFeatureDependency FeatureDependency { get; set; } // // 摘要: // A permission dependency. Only users that can satisfy this permission dependency // can see this menu item. Optional. public IPermissionDependency PermissionDependency { get; set; } //即用戶具備指定的權限時才顯示菜單 // 權限名稱 [Obsolete("Use PermissionDependency instead.")] public string RequiredPermissionName { get; set; } // The URL to navigate when this menu item is selected. public string Url { get; set; } // 菜單圖標 public string Icon { get; set; } // 排序 public int Order { get; set; } // 表示本地化字符串 public ILocalizableString DisplayName { get; set; } // 菜單名稱 public string Name { get; } // 是否顯示菜單 public bool IsVisible { get; set; } // 子菜單 public virtual List<MenuItemDefinition> Items { get; } // 添加子菜單 public MenuItemDefinition AddItem(MenuItemDefinition menuItem); // 刪除菜單: public void RemoveItem(string name); } }
從上面的代碼中,咱們能夠看到作爲一個菜單樹的相關屬性與相關方法,ABP都已經爲咱們準備好了。有了以上對象咱們能夠方便自定義任何菜單。