小試Blazor——實(shí)現(xiàn)Ant Design Blazor動態(tài)表單
時間:2023-06-25 07:34:34
前言
最近想了解下Blazor,于是嘗試使用Blazor寫一個簡單的低代碼框架,于是就采用了Ant Design Blazor作為組件庫
低代碼框架在表現(xiàn)層的第一步則是動態(tài)表單,需要將設(shè)計時的結(jié)構(gòu)渲染成運(yùn)行時的表單,本次主要實(shí)現(xiàn)動態(tài)表單,相關(guān)數(shù)據(jù)接口都以返回固定數(shù)據(jù)的形式實(shí)現(xiàn)
(相關(guān)資料圖)
實(shí)現(xiàn)
1.項目準(zhǔn)備
先通過命令創(chuàng)建一個Ant Design Blazor項目,并加入到空的解決方案當(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.菜單接口
在項目中新增Services文件夾,添加MenuServices類并填入固定數(shù)據(jù),并在Startup類中注冊:
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="動態(tài)表單", Key="Form", Icon="plus-square" } } } }; } }修改BaseicLayout.razor中@code部分,將_menuData改為從MenuService中獲?。?/p>
private MenuDataItem[] _menuData ; [Inject] public MenuService MenuService { get; set; } protected override async Task OnInitializedAsync() { await base.OnInitializedAsync(); _menuData = MenuService.GetMenuData(); }3.表單組件接口
創(chuàng)建一個簡單的表單與組件的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="賬號" }, new Input() { Name="密碼" } }); return result; } }4.動態(tài)表單頁面
在Pages文件夾下創(chuàng)建一個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項目中要訪問API接口則需要注入HttpClient類,使用HttpClient請求API接口即可,也可以直接注入Services調(diào)用。
目前僅僅是驗(yàn)證了動態(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動態(tài)表單
大學(xué)獎學(xué)金申請理由(獎學(xué)金申請理由300 500)
滿嘴跑火車!女評論員稱雷迪克是平庸射手 后者反問:你認(rèn)真的嗎|天天看熱訊
每日看點(diǎn)!端午假期最后一天 公路返程迎來峰值時段
38歲女星法蘭琪一尸兩命!懷孕5個月發(fā)生車禍,同車2個兒子昏迷
父親節(jié)蝴蝶結(jié)花束怎么做?|環(huán)球快播
北京中考語文作文題目出爐!“我讀到的北京”和“我生活中的一棵樹”二選一|全球時訊
【文體市場面面觀】鄉(xiāng)村賽事要平衡好“商味”和“村味” 世界觀天下
港交所雙柜臺模式亮相,業(yè)內(nèi):有利于更多資本流入港股|當(dāng)前資訊
環(huán)球報道:突然猛漲!有人開車10多個小時連夜搶貨!網(wǎng)友懵了:比黃金還貴?
【有色金屬】能源金屬:5月碳酸鋰進(jìn)口量環(huán)比減少10.64%,氫氧化鋰出口量環(huán)比增長8.62%
保護(hù)知識產(chǎn)權(quán)激發(fā)創(chuàng)新活力 世界觀速訊
Meta更新Quest固件,Quest 2與Quest Pro性能升級
當(dāng)前播報:啟程薩格勒布!樊振東呆萌可愛,孫穎莎開心熱聊,王楚欽大牌傍身
Theshy送出關(guān)鍵節(jié)奏,BLG遠(yuǎn)古龍怒斬WBG!Poke陣容下次真別玩了
打造“果旅融合”新路徑 小小百香果成為“致富果”“幸福果” 世界熱消息
小米畫過餅的PPT手機(jī),今天終于回來了-全球觀焦點(diǎn)
重回積分榜榜首?BLG再迎強(qiáng)敵WBG,Theshy對戰(zhàn)Bin-天天快播
書字是什么結(jié)構(gòu)的字體(書是什么結(jié)構(gòu))
環(huán)球微動態(tài)丨玩法“上新” “暑期檔”旅游持續(xù)升溫
太陽告別保羅時代!太陽老板歡迎比爾+強(qiáng)調(diào)要奪冠 曬老炮成就致謝-環(huán)球速看料
教育頻道
用戶應(yīng)用程序_關(guān)于用戶應(yīng)用程序介紹 天天觀天下
全球焦點(diǎn)!農(nóng)業(yè)農(nóng)村部部署夏季水產(chǎn)養(yǎng)殖生產(chǎn)
焦點(diǎn)快看:35只創(chuàng)業(yè)板股最新籌碼趨向集中
新款奔騰X40怎么樣及寶駿730 1.5T自動擋多少錢 世界百事通
世界速看:中國金花沖冠失?。?-2輸頭號種子,將戰(zhàn)溫網(wǎng)熱身賽,對手創(chuàng)歷史
精選!如果我找服裝設(shè)計公司給我們公司設(shè)計工作制服,那么這件服裝的著作權(quán)和版權(quán)


