译者注
ASP.NET Boilerplate是.Net平台非常优秀的一个开源Web应用程序框架,在国内也有大量的粉丝.
近日, 本人在github上闲逛, 发现ASP.NET Boilerplate团队又悄悄的建立了一个新项目: ABP vNext
从名称可以看出来, 这是ASP.NET Boilerplate的下一代框架. 那么, 为什么要开发这个新框架? 之前的框架还会继续维护吗?
ASP.NET Boilerplate团队的领导者hikalkan前几天发布了一篇博客(使用的就是ABP vNext搭建的博客系统), 详细的说明了这些问题.
本人将这篇文章翻译过来, 共享给各位读者粉丝. 全文使用Google翻译+手工润色, 不足之处, 请多包涵.
原文地址:https://abp.io/blog/abp/Abp-vNext-Announcement
转载请注明原译者(WAKU)和出处(https://www.cnblogs.com/waku/p/9708769.html)
ABP vNext介绍
介绍
过去的一段时间,我们正在设计一个新的主要版本的ASP.NET Boilerplate框架。现在,是时候与社区分享了。我们非常兴奋,相信你也是。
命名
框架的名称保持不变,除了我们将其仅称为“ABP”而不是“ASP.NET Boilerplate”。因为,“Boilerplate(样板)”会导致误解,并没反映出它是一个框架(而不是样板代码)。我们继续使用“ABP”名称,因为它是当前ASP.NET Boilerplate框架的继承者,除了它是完全重写的。
如何开始
我们已经创建了一个启动模板。您可以从abp.io/Templates创建一个新项目并开始开发。欲了解更多信息,请访问abp.io。
为什么要完全重写?
为什么我们花了宝贵的时间从头开始重写它而不是增量更改和改进。为什么?
ASP.NET Core
当我们第一次介绍ABP框架时,那是2013年(5年前)!那时候没有.Net Core和ASP.NET Core,也没有Angular2 +。ABP发布后,它们都是从头开发的。
ASP.NET Core引入了许多内置解决方案(扩展库),用于依赖注入,日志记录,缓存,本地化,配置等。它们实际上独立于ASP.NET Core,可用于任何类型的应用程序。
我们之前使用第三方库和我们自己的解决方案来满足这些要求。在它们发布后我们立即集成到ASP.NET Core功能中。但这是集成,而不是在这些扩展库之上构建ABP框架。例如,当前的ASP.NET Boilerplate依赖于Castle Windsor进行依赖注入,即使它已集成到ASP.NET Core的DI系统中。
我们希望依赖这些新的扩展库而不是第三方和自定义解决方案,这会改变框架的基本结构。
自身模块化
虽然目前的ABP本身已经是模块化的,并且包含许多包,但我们仍然希望将功能分解为更细粒度的nuget包。
例如,核心Abp包包含许多功能,如DDD类,审计,授权,后台作业,事件总线,json序列化,本地化,多租户,线程,时间等......我们希望将所有这些功能拆分到各自的包中并使它们可选。
放弃对传统技术的支持
是的,新的ABP框架将不支持ASP.NET MVC 5.x,Entity Framework 6.x和其他传统技术。
这些传统技术会由Microsoft维护,但不会再添加任何新功能。因此,如果您仍在使用这些技术,则可以继续使用当前的ASP.NET Boilerplate框架。我们将继续维护它,修复错误并添加新功能。
删除对这些传统库的支持将提高我们的开发速度(因为我们目前正在复制我们的某些功能的工作)并专注于.Net Core和ASP.NET Core。
新的ABP框架将基于.net standard。因此,仍然可以在新的ABP框架中使用完整的.net framework或.net core。
目标
我们从社区学到了很多东西,并且有开发当前ASP.NET Boilerplate框架的经验。新的ABP框架有着重要而令人兴奋的目标。
应用程序模块化
第一个目标是提供良好的基础设施来开发应用程序模块。我们将模块视为一组应用程序功能,具有自己的数据库,自己的实体,服务,API,UI页面,组件等。
我们将创建一个包含免费和付费应用程序模块的模块市场。您还可以在市场上发布自己的模块。更多信息即将推出。
微服务
我们正在设计新的ABP框架可方便的开发微服务并使它们相互通信。
我们正在设计应用程序模块,以便它们可以作为微服务单独部署,或者可以嵌入到单个应用程序中。
我们正在为此创建规范/最佳实践文档
主题和UI组合
新的ABP框架将基于最新的Twitter Bootstrap 4.x提供主题基础设施。我们开发了一个仅使用普通Bootstrap 4.x样式的基本主题。它是免费和开源的。我们还在开发高级和付费主题。
UI组合是主要目标之一。为此,主题系统将提供菜单,工具栏和其他可扩展区域,以允许其他模块交互(contribute)。
ORM / 数据库无关性和MongoDB集成
虽然当前的ASP.NET Boilerplate框架已经实现了ORM /数据库无关的存储库(Repository)模式,但身份集成模块(以Abp.Zero*命名的包)与EF以外的ORM一直运行的不太好。
使用新的ABP框架,最终目标是完全抽象的底层数据存储系统和开发与EF Core无关的模块。
我们将MongoDB作为第一级别的数据库,并在没有任何关系数据库或ORM假设的情况下设计实体和存储库。
更多可扩展性
新的ABP框架为内置服务提供了更多的扩展点和覆盖的能力。
一些功能
在本节中,我将介绍新ABP框架的一些令人兴奋的新功能。
Bootstrap Tag Helpers
我们正在创建一个库将twitter bootstrap 4.x元素/组件包装到tag helper中。例:
<abp-card>
<img abp-card-image="Top" src="~/images/my-dog.png" />
<abp-card-body>
<abp-card-title>Card title</abp-card-title>
<abp-card-text>
<p>
This is a sample card component built by ABP bootstrap
card tag helper. ABP has tag helper wrappers for most of
the bootstrap components.
</p>
</abp-card-text>
<a abp-button="Primary" href="#">Go somewhere →</a>
</abp-card-body>
</abp-card>
“abp-*”标签是ABP tag helper,用于简化为Bootstrap 4.x编写HTML。
动态表单
动态表单tag helper允许您为给定的模型类动态地创建表单。例:
<abp-dynamic-form abp-model="@Model.PersonInput" submit-button="true" />
输出:
目前支持最常用的输入类型. 更多类型正在开发中。
虚拟文件系统
虚拟文件系统允许您将视图,页面,组件,javascript,css,json和其他类型的文件嵌入到模块程序集/包(dll)中,并在任何应用程序中使用。在应用程序中您的虚拟文件就像物理文件一样, 完全的集成在ASP.NET Core中。
动态捆绑和压缩系统
动态捆绑和压缩系统运行在虚拟文件系统上,并且允许模块以模块化,动态和强大的方式创建,修改和交互捆绑包。一个例子:
<abp-style-bundle>
<abp-style type="@typeof(BootstrapStyleContributor)" />
<abp-style src="/libs/font-awesome/css/font-awesome.css" />
<abp-style src="/libs/toastr/toastr.css" />
</abp-style-bundle>
这段代码通过包含bootstrap(及其依赖项,如果有)和另外两个css文件来动态创建一个新的样式包。这些文件在生产环境中捆绑和压缩,但将在开发环境中单独添加。
有关更多信息,请参阅文档
分布式事件总线(Distributed Event Bus)
在当前的ABP中,有一个IEventBus服务来触发和处理应用程序内的事件。除了这个本地事件总线,我们还创建了一个分布式事件总线抽象(和RabbitMQ集成)来实现分布式消息传递模式。
动态C# HTTP客户端代理
ABP已经为所有HTTP API创建动态JavaScript代理。该功能也存在于新的ABP框架中。此外,它现在可以为所有HTTP API创建动态C#代理。
未来的工作
上面提到的所有东西都已经开发出来了。但是,我们还有一些想法尚未着手。
单页应用程序(Single Page Applications)
我们在设计新框架时考虑到了SPA这一点。但是,我们还没有尝试过任何SPA框架,我们还没有为它准备一个启动模板。
ASP.NET Boilerplate(当前版本)和ASP.NET Zero会如何?
我们有专门的开发和支持团队积极致力于ASP.NET Boilerplate和ASP.NET Zero项目。这些项目有一个很大的社区,我们也从社区中获得了贡献。
我们将在很长一段时间内继续为这些项目进行改进,添加新功能和修复错误。因此,您可以安全地继续使用它们。
新的ABP可用在生产环境吗?
还没有。我们的第一个目标是使基本功能稳定,然后逐步完成其他功能。
我们会经常发布新版本,每个新版本都可能会有重大变化。我们将在发行说明中写下重大更改。
我们目前将其定义为实验性质。但我们希望这不会持续很长时间。我们无法确定一个准确的日期,请关注我们的发布。
包和版本控制
新的ABP框架将从v1.0开始,而不是遵循当前的ASP.NET Boilerplate版本, 以反映它是一个重写的事实。
我们会经常发布它。你可以期待许多重大变化,直到v1.0。从v1.0开始,我们将注意不要在1.x版本中引入重大更改。
当前ABP的包名称以Abp前缀开头(如Abp.EntityFrameworkCore)。新的包名称以Volo.Abp前缀开头(如Volo.Abp.EntityFrameworkCore)。
我应该用哪一个?
如果您正在创建一个新项目,我们建议您继续使用当前的ASP.NET Boilerplate框架,因为它非常成熟,功能丰富且可用于生产环境。
如果您愿意接受重大变化并希望体验新框架,那么您可以从新的ABP开始。我们不建议在临近截止日期和在短期内上线的项目上使用它。
贡献
就像当前的ABP框架一样,您可为新框架做出贡献。
- 您可以发送代码或文档的拉取请求。
- 您可以撰写关于它的博客文章或教程。
- 您可以尝试并分享您的经验。
- 您可以提出改进和功能请求。
- 您可以报告错误和其他问题。
联系/链接
官方网站:abp.io
Github:github.com/abpframework
Twitter:@abpframework