abp模块化开发之通用树1:基本使用
一、概述
有些功能在单个项目或多个项目被重复使用,比如:附件,同一个系统中的多个模块都可能使用到,不同项目也有需要。再比如:有无限级分类的树形功能,区域、产品分类、数据字典等。最简单粗暴的办法是直接复制代码,最后本来是同一个功能被复制了多份,而且可能最后都被各自修改得面目全非。
理想的办法是将这些通用功能封装起来,通过迭代升级版本,不同项目都可以引用他们,封装的时候留出扩展点方便每个项目的个性化需求
nuget中搜索bxjg可以找到已发布的模块,源码后续会放github上,猴急的你可以私我
本篇讲解如何使用,下篇讲如何通过abp提供的模块化能力实现一个通用树模块
注:ASP.NET Boilerplate简称abp,是个啥请百个度




二、如何使用
为了各位有个直观感受,我们来看看如何使用模块,后续再讲如何开发它。
2.1、基本使用
1、通过nuget安装通用树模块(最好是所有项目都安装 解决方案 -> 右键 管理解决方案的包 一次安装)
Install-Package BXJG.GeneralTree -Version 1.0.
2、配置DbContext
public class ABPDbContext : AbpZeroDbContext<Tenant, Role, User>{
//其它配置
public virtual DbSet<GeneralTreeEntity> GeneralTrees { get; set; }
3、开启动动态webApi代理生成
public class ABPWebApiModule : AbpModule {
public override void Initialize() {
//other..
Configuration.Modules.AbpWebApi().DynamicApiControllerBuilder
.ForAll<IApplicationService>(typeof(GeneralTreeModule).Assembly, "gt/gt")
.Build();
4、数据库迁移
add-migration addGeneralTree
update-database
此时编译调试,如果你有swaggerUI的话,应该可以看得到生成的动态webapi了
5、配置权限,在core项目的AuthorizationProvider中
public class ABPAuthorizationProvider : AuthorizationProvider{
GeneralTreeModuleConfig cfg;//注入模块的配置对象
public ABPAuthorizationProvider(GeneralTreeModuleConfig cfg) {
this.cfg = cfg;
}
public override void SetPermissions(IPermissionDefinitionContext context){
//其它权限的配置
cfg.InitPermission(baseInfo);//通用字典权限的配置
6、配置菜单,配置方式跟权限配置类似。在web项目中的NavigationProvider
public class ABPNavigationProvider : NavigationProvider{
GeneralTreeModuleConfig cfg;
public ABPNavigationProvider(GeneralTreeModuleConfig cfg){
this.cfg = cfg;
}
public override void SetNavigation(INavigationProviderContext context){
//其它菜单配置
var sjzd = cfg.InitNav(jczl);
sjzd.Icon = "shuju";
sjzd.Url = "/baseinfo/generalTree/index.html";
此时你已经可用在项目中使用这个通用的数据字典模块了
2.2、扩展通用字典实现“区域”功能
1、定义实体,继承模块提供的抽象类
[Table("ABPAdministratives")]
public class AdministrativeEntity : GeneralTreeEntity<AdministrativeEntity>{
/// <summary>
/// 行政区域级别
/// </summary>
public XZQ Level { get; set; }
}
2、配置DbContext
public class ABPDbContext : AbpZeroDbContext<Tenant, Role, User>{
//其它配置
public virtual DbSet<AdministrativeEntity> Administratives { get; set; }
3、定义领域服务类
public class AdministrativeManager : GeneralTreeManager<AdministrativeEntity>{
public AdministrativeManager(IRepository<AdministrativeEntity, long> repository) : base(repository){
}
}
4、按abp常规套路实现Application中的接口和dto,偷个懒,截个图

[AutoMapFrom(typeof(AdministrativeEntity))]
public class AdministrativeDto : GeneralTreeGetTreeNodeBaseDto<AdministrativeDto> {
public XZQ Level { get; set; }
public string LevelText { get; set; }
}
[AutoMapTo(typeof(AdministrativeEntity))]
public class EditAdministrativetDto: GeneralTreeNodeEditBaseDto{
[Range(, )]
public int Level { get; set; }
} public interface IAdministrativeAppService : IGeneralTreeAppServiceBase<AdministrativeDto,EditAdministrativetDto>
{} public class AdministrativeAppService : GeneralTreeAppServiceBase<AdministrativeEntity, AdministrativeDto, EditAdministrativetDto>, IAdministrativeAppService{
public AdministrativeAppService(
IRepository<AdministrativeEntity, long> repository,
AdministrativeManager organizationUnitManager)
: base(repository,
organizationUnitManager,
PermissionNames.AdministratorBaseInfoAdministrativeAdd,
PermissionNames.AdministratorBaseInfoAdministrativeUpdate,
PermissionNames.AdministratorBaseInfoAdministrativeDelete,
PermissionNames.AdministratorBaseInfoAdministrative,
"Nationwide", "Administrative")
{} protected override void OnGetAllListItem(AdministrativeEntity entity, AdministrativeDto dto){
dto.LevelText = base.LocalizationSource.GetEnum(entity.Level);
} protected override void OnGetForSelectItem(AdministrativeEntity entity, GeneralTreeNodeDto node){
node.attributes.Level = entity.Level;
node.attributes.LevelText = base.LocalizationSource.GetEnum(entity.Level);
}
三、总结
本篇只讲了使用,下篇会详细分析如何用abp实现模块化
abp模块化开发之通用树1:基本使用的更多相关文章
- asp.net abp模块化开发之通用树2:设计思路及源码解析
一.前言 上一篇大概说了下abp通用树形模块如何使用,本篇主要分析下设计思路. 日常开发中会用到很多树状结构的数据,比如:产品的多级分类.省市区县,大多数系统也会用到类似“通用字典/数据字典”的功能, ...
- 初识ABP vNext(9):ABP模块化开发-文件管理
Tips:本篇已加入系列文章阅读目录,可点击查看更多相关文章. 目录 前言 开始 创建模块 模块开发 应用服务 运行模块 单元测试 模块使用 最后 前言 在之前的章节中介绍过ABP扩展实体,当时在用户 ...
- Android模块化开发实践
一.前言 随着业务的快速发展,现在的互联网App越来越大,为了提高团队开发效率,模块化开发已经成为主流的开发模式.正好最近完成了vivo官网App业务模块化改造的工作,所以本文就对模块化开发模式进行一 ...
- JS模块化开发:使用SeaJs高效构建页面
一.扯淡部分 很久很久以前,也就是刚开始接触前端的那会儿,脑袋里压根没有什么架构.重构.性能这些概念,天真地以为前端===好看的页面,甚至把js都划分到除了用来写一些美美的特效别无它用的阴暗角落里,就 ...
- ABP模块化
基于Abp模块化.插件化的设计,开发人员可以将自定义的功能以模块的形式集成到项目中. 模块的加载 模块: 插件: 模块及插件的加载路线: 1. 扩展的HttpApplication对象(在Abp.We ...
- 详解JavaScript模块化开发
什么是模块化开发? 前端开发中,起初只要在script标签中嵌入几十上百行代码就能实现一些基本的交互效果,后来js得到重视,应用也广泛起来了,jQuery,Ajax,Node.Js,MVC,MVVM等 ...
- Asp.net Mvc模块化开发之分区扩展框架
对于一个企业级项目开发,模块化是非常重要的. 默认Mvc框架的AreaRegistration对模块化开发真的支持很好吗?真的有很多复杂系统在使用默认的分区开发的吗?我相信大部分asp.net的技术团 ...
- JavaScript模块化开发&&模块规范
在做项目的过程中通常会有一些可复用的通用性功能,之前的做法是把这个功能抽取出来独立为一个函数统一放到commonFunctions.js里面(捂脸),实现类似于snippets的代码片段收集. fun ...
- js模块化开发——前端模块化
在JavaScript发展初期就是为了实现简单的页面交互逻辑,寥寥数语即可:如今CPU.浏览器性能得到了极大的提升,很多页面逻辑迁移到了客 户端(表单验证等),随着web2.0时代的到来,Ajax技术 ...
随机推荐
- 宋宝华:关于ARM Linux原子操作的实现
本文系转载,著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 作者: 宋宝华 来源: 微信公众号linux阅码场(id: linuxdev) 竞态无所不在 首先我们要理解竞态(ra ...
- BIOS和CMOS概念整理
一:什么是BIOS BIOS(Basic Input Output System),基本输入输出系统.是被写死在主板ROM只读芯片中的一组程序,在开机的时候首先要去读取的一个小程序. 它是我们可以将 ...
- 献给那些想自建站搭建博客的新人们(实篇)wordpress
实验材料 windows或者linux(因为我是大学操作系统学的是windows,后来服务器转向了linux,所以我将针对window和linux分别进行开展) xampp(最佳php5.6 在7.1 ...
- Java 添加Word形状或图形
本文将介绍通过java编程在Word文档中添加形状(图形),包括添加单个图形.组合图形,以及格式化图形样式,如设置形状填充色.大小.位置.边框样式.边框颜色.边框粗细.图形旋转角度.图形文本环绕方式等 ...
- C# VS2019 WebService创建与发布,并部署到Windows Server 2012R
前言 上一次数据库灾备和性能优化后,数据库专家建议,在不扩容的情况下,客户端不能再频繁的扫描数据库了!一句惊醒梦中人,因为我也发现数据库越来越卡了,自从上个项目上线后,就出现了这个情况.后来分析其原因 ...
- MySQL 库、表、记录、相关操作(3)
MySQL 库.表.记录.相关操作(3) 单表查询 """ 增: insert [into] [数据库名.]表名[(字段1[, ..., 字段n])] values (数 ...
- windows虚拟机中DNS服务配置
在linux虚拟机中进行DNS服务配置并进行正向解析反向解析我博客中已经写过,下面 我来介绍一下在windows虚拟机中DNS服务的配置使用. 1.打开一台windows虚拟机中服务器管理器——角色— ...
- xcode8 运行项目时自己打印些东西
使用 Xcode 8 运行工程的时候,在打印台会发现如下这些奇怪的日志输出: 2016-09-19 10:43:44.001757 Demo[7100:171568] subsystem: com.a ...
- 基本shell脚本
#!/bin/bash attr=() num= while true do read -p ">>input:" name attr[$num]=$name echo ...
- (一)sync分析之为啥el-dialog中的visible需要使用.sync
首先,笔者在使用element-ui 中的dialog组件时,发现visible属性在使用时需要添加.sync才生效,心中好奇,所以研究一下原理 我们先自己创建一个dialog组件,如下 当我们点击关 ...