欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

asp.net?core實體類生產(chǎn)CRUD后臺管理界面

 更新時間:2022年05月19日 16:26:13   作者:dotnetCore  
這篇文章主要為大家介紹了asp.net?core實體類生產(chǎn)CRUD后臺管理界面詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

前言介紹

喜歡小規(guī)模團隊的"單打獨斗",有的時候即使在大公司,也經(jīng)常做著3-5個人團隊的小項目,相信很多人有類似的經(jīng)歷。

本文介紹如何將項目中已存在的【實體類】,直接生產(chǎn)出 CRUD 后臺管理界面。

對于通用后臺管理系統(tǒng)的生成,除了單純的對單表 crud 操作外,我還喜歡利用導(dǎo)航屬性的操作,比如:

1、Song、Tag 多對多場景,添加/更新 Song 時可以把 Tag 一起保存;

2、列表頁,希望外鍵、多對多出現(xiàn)在過濾篩選條件;

3、列表頁,希望枚舉出現(xiàn)在過濾篩選條件;

4、刪除時,級聯(lián)刪除所有相關(guān)數(shù)據(jù);

等等諸如此類的繁瑣操作,之所以說繁瑣,是因為這些工作技術(shù)不難,屬于嚴(yán)重的重復(fù)勞動。

在人員配備苛刻的環(huán)境下,選擇盡量靠工具提高生產(chǎn)效率,這樣我們才有更多的時間在上班摸魚。。。

演示功能

Domain 目錄下的文件是【實體類】

Program.cs 是 asp.net core 啟動代碼

using FreeSql;
using ojbk.Entities;
var fsql = new FreeSql.FreeSqlBuilder()
    .UseConnectionString(FreeSql.DataType.Sqlite, @"Data Source=test.db;Pooling=true;Max Pool Size=10")
    .UseAutoSyncStructure(true)
    .UseNoneCommandParameter(true)
    .UseMonitorCommand(cmd => Console.WriteLine(cmd.CommandText + "\r\n"))
    .Build();
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllersWithViews();
builder.Services.AddSingleton(fsql);
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
var app = builder.Build();
if (app.Environment.IsDevelopment())
{
    app.UseSwagger();
    app.UseSwaggerUI();
}
app.UseAuthorization();
app.MapControllers();
app.UseDefaultFiles();
app.UseStaticFiles();
/******************************* 以下是核心代碼 **************************/
app.UseFreeAdminLtePreview("/",
    typeof(Config),
    typeof(Role),
    typeof(Menu),
    typeof(User),
    typeof(Department),
    typeof(Employee),
    typeof(Position),
    typeof(AppLog),
    typeof(LoginLog),
    typeof(OprationLog),
    typeof(IdleScheduler.TaskInfo),
    typeof(IdleScheduler.TaskLog)
);
app.Run();

既然 ORM 已經(jīng)對實體進行了配置,利用已存在的條件便利的產(chǎn)生后臺管理功能,真是一大快事??!

它是 FreeSql 衍生出來的 .NETCore MVC 中間件擴展包 FreeSql.AdminLTE.dll,基于 AdminLTE 前端框架動態(tài)產(chǎn)生實體的增刪查改界面;

輸入:實體1、實體2、實體3

輸出:后臺管理的功能

只需要傳入實體,就可以生產(chǎn) curd 的管理功能,是不是有些騷啊~~~

先發(fā)幾張運行后的圖片嘗個鮮:

這是根據(jù)實體產(chǎn)生 curd 界面的 mvc 中間件,開發(fā)時預(yù)覽或簡單管理數(shù)據(jù)好方便啊??赐觐A(yù)覽圖不由得再感嘆一次 FreeSql 的易用性,那句口號:做 .NETCore 最方便的 ORM! 沒有說錯。。。作者多次提及:“我們是簡約風(fēng)格,沒那么復(fù)雜的用法”,也驗證了這一點。。

機制設(shè)定

1、添加、修改數(shù)據(jù)

中件間產(chǎn)生的界面包括添加、修改數(shù)據(jù)的功能,普通實體的根據(jù)屬性的類型與 Html5 UI 一一映射;

比較特殊的映射規(guī)則:

c# 類型Html5
布爾復(fù)選框
枚舉下拉選擇
日期日期控件
ManyToOne 導(dǎo)航屬性下拉選擇
ManyToMany 導(dǎo)航屬性多選器

等等。。。

什么情況會產(chǎn)生【上傳文件】控件?

有興趣的可以了解源碼,目前沒有開放在外部配置。

2、列表查詢、過濾篩選

中件間為每個實體提供了分頁列表查詢,每頁為20條數(shù)據(jù);

除此外,還提供了過濾條件的支持,規(guī)則是根據(jù)導(dǎo)航屬性(ManyToOne、ManyToMany)。比如【崗位】,內(nèi)含有【部門 Department】、【員工 Employee】、【角色 Role】,則【崗位】列表頁會出現(xiàn)按【分類】篩選的UI,詳見上面的 demo 示意圖,或者下載 demo 運行;

3、刪除數(shù)據(jù)

中件間為每個實體提供了批量刪除的功能;

并且支持了復(fù)雜導(dǎo)航屬性關(guān)系的級聯(lián)刪除功能,而這個功能不依賴數(shù)據(jù)庫外鍵;

下載 Demo

我們一直習(xí)慣用 sqlite 做測試庫,測試完畢直接刪除目錄,不留垃圾數(shù)據(jù),所以下面的 demo 不需要修改任何地方,運行時自動建庫、建表;

運行環(huán)境:.net6.0

點擊下載

第一步:

dotnet restore

第二步:

dotnet run

將監(jiān)聽的地址復(fù)制,打開 chrome 瀏覽器粘貼訪問。

思考人生

一番驚喜過后,你應(yīng)該會考慮實用性,這樣做有什么價值,可用于什么樣的場景?

這個擴展包簡單的輸入,產(chǎn)生巨量的功能反饋。但由于生成的代碼是 mvc + razor + jquery + AdminLTE,決定它很難在這個時代開花結(jié)果。

思路方向應(yīng)該不會有問題,因為真的太方便了,如果生成后的代碼是 Service + Vue + ElementUI,并且還提供了默認(rèn)通用權(quán)限、定時任務(wù)等功能,就問香不香?

期待有興趣志同道合的人改造。

github:

https://github.com/2881099/FreeSql.AdminLTE

以上就是asp.net core實體類生產(chǎn)CRUD后臺管理界面的詳細(xì)內(nèi)容,更多關(guān)于asp.net core實體類生產(chǎn)CRUD的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論