小試Blazor——實(shí)現(xiàn)Ant Design Blazor動(dòng)態(tài)表單-天天快看點(diǎn)
時(shí)間:2023-06-25 07:05:53
前言
最近想了解下Blazor,于是嘗試使用Blazor寫(xiě)一個(gè)簡(jiǎn)單的低代碼框架,于是就采用了Ant Design Blazor作為組件庫(kù)
低代碼框架在表現(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)
【資料圖】
實(shí)現(xiàn)
1.項(xiàng)目準(zhǔn)備
先通過(guò)命令創(chuàng)建一個(gè)Ant Design Blazor項(xiàng)目,并加入到空的解決方案當(dāng)中:
dotnet new antdesign -o LowCode.Web -ho server
由于我們需要寫(xiě)一些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="測(cè)試模塊", 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中獲?。?/p>
private MenuDataItem[] _menuData ; [Inject] public MenuService MenuService { get; set; } protected override async Task OnInitializedAsync() { await base.OnInitializedAsync(); _menuData = MenuService.GetMenuData(); }3.表單組件接口
創(chuàng)建一個(gè)簡(jiǎn)單的表單與組件的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)表單頁(yè)面
在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)目中要訪問(wèn)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倉(cāng)庫(kù)
相關(guān)稿件
小試Blazor——實(shí)現(xiàn)Ant Design Blazor動(dòng)態(tài)表單-天天快看點(diǎn)
環(huán)球快消息!沈陽(yáng)鐵路局王占柱處長(zhǎng)(沈陽(yáng)鐵路局王占柱)
世界熱推薦:捷豹路虎中國(guó)和捷豹路虎寧波召回車輛 凸輪軸支架機(jī)油油道未鉆通
一考生查分 全家一起喊出666 應(yīng)該可以沖復(fù)旦和交大! 環(huán)球熱議
方坑嶺影視基地簽約!《老炮敢死隊(duì)》后天開(kāi)機(jī)
山東黃金集團(tuán)推廣開(kāi)展典型案例解剖式調(diào)研、“代入式”調(diào)研經(jīng)驗(yàn)做法
曝具俊曄回韓國(guó),留大S獨(dú)自面對(duì)風(fēng)波,誰(shuí)是真愛(ài)與汪小菲對(duì)比明顯
強(qiáng)鏈延鏈贏得發(fā)展主動(dòng)權(quán)——訪恒力集團(tuán)董事長(zhǎng)、總裁陳建華|當(dāng)前播報(bào)
中央氣象臺(tái)6月25日06時(shí)繼續(xù)發(fā)布暴雨黃色預(yù)警
世界報(bào)道:黃浦區(qū)將規(guī)劃布局“兩點(diǎn)一線” 打造外灘法律服務(wù)集聚帶
僅4人踢遍五大聯(lián)賽:拉杜喬尤&鮑爾森&約維蒂奇&小克魯伊維特_天天精選
環(huán)球報(bào)道:我爸是李鋼案件詳情(我爸是李剛造句)
烏蘇市氣象臺(tái)發(fā)布雷電黃色預(yù)警[Ⅲ級(jí)/較重] 【2023-06-24】
世界最新:俄媒:俄南部軍區(qū)位于羅斯托夫的總部大樓被“瓦格納”成員包圍
ChatGPT 六大勁敵:技術(shù)狂熱者、天才 95 后、硅谷人脈王
谷歌或?qū)⑵銹ixel手機(jī)部分生產(chǎn)轉(zhuǎn)移到印度
Theshy送出關(guān)鍵節(jié)奏,BLG遠(yuǎn)古龍怒斬WBG!Poke陣容下次真別玩了
6-3,6-4!阿爾卡拉斯橫掃繼續(xù)前進(jìn),生涯首進(jìn)草地賽事決賽
天天新消息丨沙特阿美與道達(dá)爾能源授予110億美元沙特石化設(shè)施擴(kuò)建項(xiàng)目合同
瓦格納創(chuàng)始人被訴武裝叛亂,俄國(guó)民警衛(wèi)隊(duì)中央?yún)^(qū)軍官進(jìn)入緊急狀態(tài)|世界視訊
全球速看:推動(dòng)品牌建設(shè)上臺(tái)階
全球通訊!國(guó)際范兒,龍舟“劃”向世界!端午節(jié)已成全人類共同文化遺產(chǎn)
世界新動(dòng)態(tài):中國(guó)女排遭遇升級(jí)版挑戰(zhàn)
百事通!國(guó)內(nèi)首條跨省軌交系統(tǒng)無(wú)感換乘線路開(kāi)通


