小試Blazor——實現Ant Design Blazor動態表單-天天快看點
時間:2023-06-25 07:05:53
前言
最近想了解下Blazor,于是嘗試使用Blazor寫一個簡單的低代碼框架,于是就采用了Ant Design Blazor作為組件庫
低代碼框架在表現層的第一步則是動態表單,需要將設計時的結構渲染成運行時的表單,本次主要實現動態表單,相關數據接口都以返回固定數據的形式實現
【資料圖】
實現
1.項目準備
先通過命令創建一個Ant Design Blazor項目,并加入到空的解決方案當中:
dotnet new antdesign -o LowCode.Web -ho server
由于我們需要寫一些API接口,所以在Startup類中加入控制器相關的代碼:
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類并填入固定數據,并在Startup類中注冊:
public class MenuService { ////// 獲取左側導航數據 /// ///public virtual MenuDataItem[] GetMenuData() { return new MenuDataItem[] { new MenuDataItem { Path="/", Name="測試模塊", Key="Test", Icon="smile", Children=new MenuDataItem[] { new MenuDataItem { Path="/StdForm", Name="動態表單", 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.表單組件接口
創建一個簡單的表單與組件的Model:
錄入控件Input:
public class Input { public string Name { get; set; } public string Value { get; set; } }
標準表單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.動態表單頁面
在Pages文件夾下創建一個StdForm.razor和StdForm.razor.cs文件
StdForm.razor.cs(注意partial):
public partial class StdForm { public StandardFormModel StandardFormModel { get; set; } public FormStdFormModel { 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"
運行效果
總結
在Blazor項目中要訪問API接口則需要注入HttpClient類,使用HttpClient請求API接口即可,也可以直接注入Services調用。
目前僅僅是驗證了動態表單的可能性,其他的組件渲染可以根據Ant Design Blazor官方文檔定義模型結構實現
參考文檔:
Blazor官方文檔
Ant Design Blazor官方文檔
Ant Design Blazor倉庫
相關稿件
小試Blazor——實現Ant Design Blazor動態表單-天天快看點
世界熱推薦:捷豹路虎中國和捷豹路虎寧波召回車輛 凸輪軸支架機油油道未鉆通
一考生查分 全家一起喊出666 應該可以沖復旦和交大! 環球熱議
山東黃金集團推廣開展典型案例解剖式調研、“代入式”調研經驗做法
曝具俊曄回韓國,留大S獨自面對風波,誰是真愛與汪小菲對比明顯
強鏈延鏈贏得發展主動權——訪恒力集團董事長、總裁陳建華|當前播報
世界報道:黃浦區將規劃布局“兩點一線” 打造外灘法律服務集聚帶
僅4人踢遍五大聯賽:拉杜喬尤&鮑爾森&約維蒂奇&小克魯伊維特_天天精選
烏蘇市氣象臺發布雷電黃色預警[Ⅲ級/較重] 【2023-06-24】
世界最新:俄媒:俄南部軍區位于羅斯托夫的總部大樓被“瓦格納”成員包圍
ChatGPT 六大勁敵:技術狂熱者、天才 95 后、硅谷人脈王
Theshy送出關鍵節奏,BLG遠古龍怒斬WBG!Poke陣容下次真別玩了
6-3,6-4!阿爾卡拉斯橫掃繼續前進,生涯首進草地賽事決賽
天天新消息丨沙特阿美與道達爾能源授予110億美元沙特石化設施擴建項目合同
瓦格納創始人被訴武裝叛亂,俄國民警衛隊中央區軍官進入緊急狀態|世界視訊