小試Blazor——實(shí)現(xiàn)Ant Design Blazor動(dòng)態(tài)表單_關(guān)注
時(shí)間:2023-06-25 06:00:25
前言
最近想了解下Blazor,于是嘗試使用Blazor寫一個(gè)簡單的低代碼框架,于是就采用了Ant Design Blazor作為組件庫
低代碼框架在表現(xiàn)層的第一步則是動(dòng)態(tài)表單,需要將設(shè)計(jì)時(shí)的結(jié)構(gòu)渲染成運(yùn)行時(shí)的表單,本次主要實(shí)現(xiàn)動(dòng)態(tài)表單,相關(guān)數(shù)據(jù)接口都以返回固定數(shù)據(jù)的形式實(shí)現(xiàn)
(相關(guān)資料圖)
實(shí)現(xiàn)
1.項(xiàng)目準(zhǔn)備
先通過命令創(chuàng)建一個(gè)Ant Design Blazor項(xiàng)目,并加入到空的解決方案當(dāng)中:
dotnet new antdesign -o LowCode.Web -ho server
由于我們需要寫一些API接口,所以在Startup類中加入控制器相關(guān)的代碼:
public void ConfigureServices(IServiceCollection services) { services.AddRazorPages(); services.AddControllers();//添加控制器 services.AddEndpointsApiExplorer(); services.AddServerSideBlazor(); services.AddAntDesign(); services.AddScoped(sp => new HttpClient { BaseAddress = new Uri(sp.GetService().BaseUri) }); services.Configure(Configuration.GetSection("ProSettings")); } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Error"); // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. app.UseHsts(); } app.UseHttpsRedirection(); app.UseStaticFiles(); app.UseRouting(); app.UseEndpoints(endpoints => { endpoints.MapBlazorHub(); endpoints.MapFallbackToPage("/_Host"); endpoints.MapControllers();//配置控制器 }); } 2.菜單接口
在項(xiàng)目中新增Services文件夾,添加MenuServices類并填入固定數(shù)據(jù),并在Startup類中注冊(cè):
public class MenuService { /// /// 獲取左側(cè)導(dǎo)航數(shù)據(jù) /// /// public virtual MenuDataItem[] GetMenuData() { return new MenuDataItem[] { new MenuDataItem { Path="/", Name="測試模塊", Key="Test", Icon="smile", Children=new MenuDataItem[] { new MenuDataItem { Path="/StdForm", Name="動(dòng)態(tài)表單", Key="Form", Icon="plus-square" } } } }; } }修改BaseicLayout.razor中@code部分,將_menuData改為從MenuService中獲取:
private MenuDataItem[] _menuData ; [Inject] public MenuService MenuService { get; set; } protected override async Task OnInitializedAsync() { await base.OnInitializedAsync(); _menuData = MenuService.GetMenuData(); }3.表單組件接口
創(chuàng)建一個(gè)簡單的表單與組件的Model:
錄入控件Input:
public class Input { public string Name { get; set; } public string Value { get; set; } }標(biāo)準(zhǔn)表單StandardFormModel:
public class StandardFormModel { public StandardFormModel() { ArrayInput = new List(); } public List ArrayInput { get; set; } }表單API接口FormController:
[Route("api/[controller]/[action]")] [ApiController] public class FormController : ControllerBase { [HttpGet] public StandardFormModel GetFormStruc() { var result = new StandardFormModel(); result.ArrayInput.AddRange(new List(){ new Input() { Name="賬號(hào)" }, new Input() { Name="密碼" } }); return result; } }4.動(dòng)態(tài)表單頁面
在Pages文件夾下創(chuàng)建一個(gè)StdForm.razor和StdForm.razor.cs文件
StdForm.razor.cs(注意partial):
public partial class StdForm { public StandardFormModel StandardFormModel { get; set; } public Form StdFormModel { get; set; } [Inject] public HttpClient HttpClient { get; set; } public void Init() { var formStruc = HttpClient.GetFromJsonAsync("api/Form/GetFormStruc").Result; StandardFormModel= formStruc; } protected override async Task OnInitializedAsync() { Init(); await base.OnInitializedAsync(); } } StdForm.razor:
@page "/StdForm"
運(yùn)行效果
總結(jié)
在Blazor項(xiàng)目中要訪問API接口則需要注入HttpClient類,使用HttpClient請(qǐng)求API接口即可,也可以直接注入Services調(diào)用。
目前僅僅是驗(yàn)證了動(dòng)態(tài)表單的可能性,其他的組件渲染可以根據(jù)Ant Design Blazor官方文檔定義模型結(jié)構(gòu)實(shí)現(xiàn)
參考文檔:
Blazor官方文檔
Ant Design Blazor官方文檔
Ant Design Blazor倉庫
相關(guān)稿件
小試Blazor——實(shí)現(xiàn)Ant Design Blazor動(dòng)態(tài)表單_關(guān)注
全球觀天下!血小板體積分布寬度偏高應(yīng)該注意什么_血小板體積分布寬度偏高會(huì)怎么樣
廣州未來30天天氣預(yù)報(bào)最準(zhǔn)_廣州未來30天天氣預(yù) 世界熱點(diǎn)
水管什么牌子好性價(jià)比高_(dá)水管什么牌子好 熱資訊
局地氣溫達(dá)40℃!中央氣象臺(tái)繼續(xù)發(fā)布高溫橙色預(yù)警 熱門看點(diǎn)
游子歸鄉(xiāng)打一中藥材_游子歸鄉(xiāng)打一中藥-環(huán)球熱點(diǎn)評(píng)
環(huán)球動(dòng)態(tài):好騷啊,這新機(jī)絕對(duì)是來搗亂的
年內(nèi)漲幅近60%,北交所“白馬股”獲機(jī)構(gòu)組團(tuán)調(diào)研
全球視點(diǎn)!去銀行存錢,究竟該選一年期還是三年期?答案揭曉,別再存錯(cuò)了
焦點(diǎn)訊息:宣布已有5年之久:微軟稱《上古卷軸6》2028年前不會(huì)發(fā)售
黃智雯多次避談離巢!樂易玲突發(fā)文公開稱贊,出招留人?
重慶高考查分幾點(diǎn)?重慶成績查詢?nèi)肟冢褐貞c市教育考試院網(wǎng)站、重慶招考信息網(wǎng)
文班亞馬:昨晚和吉諾比利&鄧肯&海軍上將共進(jìn)晚餐 對(duì)NBA了解更深
圓的體積計(jì)算公式是什么?_圓的體積計(jì)算公式是什么 天天通訊
教育頻道
央媒說“寧” | 非遺游、避暑游、文化游……端午假期這些消費(fèi)新體驗(yàn)等你打卡!|熱點(diǎn)評(píng)
當(dāng)前短訊!陜西勉縣一村支書毆打村民致住院?當(dāng)?shù)卮甯刹浚簝扇舜_有爭執(zhí)
圖片報(bào):目前沒跡象表明穆阿尼會(huì)離隊(duì),沒有報(bào)價(jià)并且球員無意離隊(duì)
山東黃金集團(tuán)推廣開展典型案例解剖式調(diào)研、“代入式”調(diào)研經(jīng)驗(yàn)做法_全球快訊
尚太科技:二季度應(yīng)用于儲(chǔ)能電池的負(fù)極材料出貨量處于爬坡階段-全球速看料
世界簡訊:信用利差周報(bào):公用事業(yè)、地產(chǎn)利差小幅走闊
用vlookup函數(shù)比對(duì)兩個(gè)表的相同數(shù)據(jù)(vlookup比對(duì)兩表數(shù)據(jù)查找不同數(shù))


