abp(net core)+easyui+efcore實現倉儲管理系統——菜單-上 (十六)

abp(net core)+easyui+efcore實現倉儲管理系統目錄

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等數據源中加載一些動態菜單來知足咱們的系統要求。

今天咱們就來實現這個功能,動態加載菜單。所要加載的菜單就是模塊管理中的功能模塊。

1、菜單項類

       一個應用程序可能包含不一樣的模塊,而每一個模塊均可能有它本身的菜單項。在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都已經爲咱們準備好了。有了以上對象咱們能夠方便自定義任何菜單。

相關文章
相關標籤/搜索