国产美女主播视频一区_国产精品蜜臀在线观看_亚洲成人动漫一区_亚洲视屏在线播放

首頁 > 文化

小試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"
@foreach (var item in StandardFormModel.ArrayInput) { @if (item is Model.Component.Input) { } }

運(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)

平湖市發(fā)布黃色暴雨預(yù)警

鐘正生丨日本股市為何領(lǐng)漲:基于全球比較的邏輯

水管什么牌子好性價(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ì)是來搗亂的

每日消息!語文一年級(jí)—高怎么組詞?

京東上買到假貨可以申請(qǐng)幾倍賠償嗎_京東 假貨

如何編蝴蝶結(jié)?

工商銀行存折余額查詢?nèi)肟赺工商銀行存折余額查詢

年內(nèi)漲幅近60%,北交所“白馬股”獲機(jī)構(gòu)組團(tuán)調(diào)研

全球視點(diǎn)!去銀行存錢,究竟該選一年期還是三年期?答案揭曉,別再存錯(cuò)了

楊某等7人,被廈門警方抓獲!_全球視點(diǎn)

焦點(diǎn)訊息:宣布已有5年之久:微軟稱《上古卷軸6》2028年前不會(huì)發(fā)售

黃智雯多次避談離巢!樂易玲突發(fā)文公開稱贊,出招留人?

光明vs黑暗3.40隱藏_光明vs黑暗3 42隱藏英雄

世界快看點(diǎn)丨memcached使用中踩的一些坑

重慶高考查分幾點(diǎn)?重慶成績查詢?nèi)肟冢褐貞c市教育考試院網(wǎng)站、重慶招考信息網(wǎng)

文班亞馬:昨晚和吉諾比利&鄧肯&海軍上將共進(jìn)晚餐 對(duì)NBA了解更深

環(huán)球視訊!出場原則

天天百事通!一張粽葉包萬物!700多年前的粽子長什么樣?

憂郁蘑菇的正確用法_憂郁蘑菇_世界焦點(diǎn)

端午假期返程高峰要來了!云南各地最新路況→ 每日速遞

圓的體積計(jì)算公式是什么?_圓的體積計(jì)算公式是什么 天天通訊

今日視點(diǎn):收藏!高考查分報(bào)志愿時(shí)間表

唐伯虎什么生肖(唐伯虎是什么生肖?)

每日訊息!什么牌子的平板好用(平板電腦什么牌子好用?)


主站蜘蛛池模板: 亚洲 国产 日韩 综合一区| 亚洲欧洲一区二区| 亚洲视频在线观看日本a| 久久精品国产69国产精品亚洲| 日本三日本三级少妇三级66| 国产传媒久久久| 在线精品日韩| 亚洲午夜久久久影院伊人| 五月天色婷婷综合| 在线观看国产一区| 欧美一区二区三区精品电影 | 久久久久国产精品免费| 国产极品尤物在线| 国产精品久久精品国产| 日本久久久久亚洲中字幕| 久久精品ww人人做人人爽| 中文字幕在线亚洲精品| 热久久这里只有精品| 91久久精品国产| 国产传媒久久久| 国产精品天天狠天天看| 久久精品人人做人人爽| 大波视频国产精品久久| 国内精品久久久久伊人av| 久久国产日韩欧美| 中文字幕一区二区三区四区五区六区| 久久九九免费视频| 亚洲精品日韩av| 九九热精品视频| 久久精品国亚洲| 欧美激情国产精品| 久久久神马电影| 欧美不卡视频一区发布| 久久精品视频亚洲| 亚洲精品一区二区三| 国产精品美女在线观看| 欧美视频在线第一页| 久久网站免费视频| 国产亚洲精品网站| 日本一区视频在线播放| 久久久这里只有精品视频|