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技术 ...
随机推荐
- 程序员用于机器学习数据科学的3个顶级 Python 库
NumPy NumPy(数值 Python 的简称)是其中一个顶级数据科学库,它拥有许多有用的资源,从而帮助数据科学家把 Python 变成一个强大的科学分析和建模工具.NumPy 是在 BSD 许可 ...
- es3设置属性不能修改
/*es3*/ { var Person =function () { var data ={ name:'zs', sex:'男', age:18 } this.get=function (key) ...
- Python开发-实现Excel套打打印
一.目的 目前本人就职与甲方的工作,由于公司的ERP比较烂无法完美的设计套打,就想着自己用Python开发一个套打工具. 二.开发过程 刚开始我打算用Html的方式生成打印的文档,但是有两个无法解决的 ...
- 【Android - 控件】之V - Toolbar的使用
Toolbar是Android V7包中的一个控件,用来代替Action Bar作为界面的头部标题栏布局.Toolbar相对于Action Bar的特点是更加灵活,可以显示在任何位置. 首先先来看To ...
- telnet指令研究—以网络聊天程序为例
一.telnet指令 Telnet取名自Telecommunications和Networks的联合缩写,是早期个人计算机上连接到服务器主机的一个网络指令,由于存在安全问题,现在已经很少被使用.在wi ...
- salesforce lightning零基础学习(十六) 公用组件之 获取字段label信息
我们做的项目好多都是多语言的项目,针对不同国家需要展示不同的语言的标题.我们在classic中的VF page可谓是得心应手,因为系统中已经封装好了我们可以直接在VF获取label/api name等 ...
- 关于python中的列表遍历注意事项
在开发过程中,很容易出现以下的错误: 可以看出:假如删除列表的元素之后直接执行continue,那么遍历的时候就会落下一个元素. 那么怎么解决这个问题呢? 首先 : 我们尝试把continue去掉: ...
- R 语言学习笔记(1)——R 工作空间与输入输出
什么是工作空间? 工作空间(workspace)就是当前 R 的工作环境,它储存着所有用户定义的对象(objectives)包括了向量.矩阵.函数.数据框.列表等. 处理 R 文件的工作流程 #设置当 ...
- C语音I博客作业09
------------恢复内容开始------------ 这个作业属于那个课程|C语言程序设计II --|:--:|--: 这个作业要求在哪里|https://edu.cnblogs.com/ca ...
- vscode从听说到使用,vetur,prettier,htmljscssPrettify踩坑指南。
今天基于vue-cli(2.9.3)构建一个新的项目.我用的sublime,es6的代码格式要与公司格式兼容.采用了vue-cli自带的eslint后,有一些不统一的部分需要修改.先看看sublime ...