久久精品123,午夜国产欧美理论在线播放,国产精品影视天天线,国内自拍亚洲

您的位置:首頁>新聞 > 觀察 >

小試Blazor——實現Ant Design Blazor動態表單

2023-06-25 09:28:06    來源:博客園

前言


(資料圖片僅供參考)

最近想了解下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中獲?。?/p>

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 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) { } }

運行效果

總結

在Blazor項目中要訪問API接口則需要注入HttpClient類,使用HttpClient請求API接口即可,也可以直接注入Services調用。

目前僅僅是驗證了動態表單的可能性,其他的組件渲染可以根據Ant Design Blazor官方文檔定義模型結構實現

參考文檔:

Blazor官方文檔

Ant Design Blazor官方文檔

Ant Design Blazor倉庫

關鍵詞:

相關閱讀

久久精品123,午夜国产欧美理论在线播放,国产精品影视天天线,国内自拍亚洲
亚洲日本在线观看| 老色鬼久久亚洲一区二区| 久久亚洲精品欧美| 午夜亚洲福利在线老司机| 国产亚洲电影| 91久久国产综合久久91精品网站| 日韩视频中午一区| 久久亚洲欧美国产精品乐播| 老司机aⅴ在线精品导航| 销魂美女一区二区三区视频在线| 欧美影院视频| 国产精品久久久久久久久久直播| 欧美精品v国产精品v日韩精品| 亚洲激情第一页| 免费成人毛片| 国产精品一区二区你懂得| 亚洲天堂av在线免费观看| 欧美α欧美αv大片| 欧美色图首页| 亚洲欧美成人一区二区在线电影| 久久精品五月婷婷| 亚洲视频碰碰| 国产一区二区三区精品久久久| 国产欧美69| 国产精品美女久久久免费| 欧美在线观看网址综合| 国产精品黄色在线观看| 国产欧美日韩三区| 久久久综合激的五月天| 欧美精品一区二区三区高清aⅴ| 99re热这里只有精品免费视频| 日韩一二三在线视频播| 亚洲一区国产精品| 国产日韩欧美一区在线| 久久久最新网址| 一区二区三区欧美日韩| 狼人社综合社区| 午夜精品国产精品大乳美女| 在线亚洲国产精品网站| 国精产品99永久一区一区| av成人免费观看| 夜夜嗨av一区二区三区四区| 99国产精品久久久久久久成人热| 亚洲精品影院| 久久爱www.| 欧美另类一区| 久久久不卡网国产精品一区| 久久久久99精品国产片| 亚洲欧美一区二区三区极速播放| 欧美日韩一区二区在线| 欧美日韩另类丝袜其他| 欧美激情女人20p| 欧美freesex交免费视频| 亚洲精品免费观看| 中日韩美女免费视频网站在线观看| 国产亚洲精品bv在线观看| 欧美日韩亚洲国产一区| 久热精品视频在线| 国产专区欧美精品| 久久天天躁夜夜躁狠狠躁2022| 国产一区深夜福利| 亚洲国产欧美不卡在线观看| 一区二区三区 在线观看视| 国产一区视频在线看| 在线观看成人小视频| 国产精品久久久久久户外露出| 韩日在线一区| 亚洲二区在线观看| 中日韩视频在线观看| 久久综合伊人77777| 曰本成人黄色| 欧美亚州韩日在线看免费版国语版| 国产女人水真多18毛片18精品视频| 国产精品久久久久久久久久免费| 亚洲欧美日韩精品久久亚洲区| 久久综合久久久久88| 欧美精品成人| 欧美一区深夜视频| 国产真实久久| 国内成人精品视频| 欧美jizz19hd性欧美| 欧美性片在线观看| 香蕉尹人综合在线观看| 欧美三级午夜理伦三级中视频| 久久久av网站| 久久久久久久久久久久久女国产乱| 欧美一区二区视频观看视频| 亚洲黄色尤物视频| 免费黄网站欧美| 91久久国产自产拍夜夜嗨| 99国产精品久久| 亚洲欧美第一页| 亚洲欧美日韩专区| 日韩一级不卡| 久久国产精品黑丝| 最新日韩精品| 国产精品久久久久一区| 国产伦精品免费视频| 亚洲精品综合| 久久频这里精品99香蕉| 欧美精品xxxxbbbb| 久久亚洲春色中文字幕久久久| 亚洲欧美日韩国产综合精品二区| 欧美v国产在线一区二区三区| 国产精品一区在线观看你懂的| 国模一区二区三区| 国产私拍一区| 一区二区视频在线观看| 欧美xxx成人| 欧美日韩国产亚洲一区| 国产综合久久久久久| 欧美怡红院视频一区二区三区| 国内精品视频一区| 久久国产精品久久久久久久久久| 欧美激情一区二区| 久久亚洲精品欧美| 中日韩美女免费视频网址在线观看| 欧美成人精品一区| 亚洲亚洲精品三区日韩精品在线视频| 久久久久久亚洲精品不卡4k岛国| 亚洲人被黑人高潮完整版| 麻豆成人在线播放| 一本高清dvd不卡在线观看| 国产精一区二区三区| 最新国产の精品合集bt伙计| 久久激情视频免费观看| 宅男噜噜噜66国产日韩在线观看| 国产精品系列在线| 亚洲调教视频在线观看| 国产欧美日韩一区二区三区在线| 久久亚洲国产成人| 欧美一区二区三区视频在线观看| 亚洲欧美日韩在线高清直播| 久热精品视频在线观看一区| 欧美日韩国产成人在线观看| 久久久久国产精品人| 亚洲国产精品激情在线观看| 日韩写真视频在线观看| 免费影视亚洲| 女人天堂亚洲aⅴ在线观看| 一区二区欧美国产| 欧美v亚洲v综合ⅴ国产v| 亚洲日本乱码在线观看| 国产精品色婷婷| 黄网站免费久久| 国产精品毛片在线看| 在线成人性视频| 国产美女高潮久久白浆| 国产一区二区三区不卡在线观看| 影音先锋日韩有码| 欧美高清视频一区二区三区在线观看| 欧美人成在线| 久久成人av少妇免费| 亚洲人成欧美中文字幕| 女人天堂亚洲aⅴ在线观看| 久久精品系列| 国产精品v欧美精品∨日韩| 久久亚洲国产精品日日av夜夜| 国产综合色在线| 在线亚洲精品福利网址导航| 国产女精品视频网站免费| 国产精品日本| 亚洲免费黄色| 久久久精品国产免大香伊| 欧美激情亚洲| 日韩一二在线观看| 国产精品久久久久久久久久妞妞| 国产一区二区三区丝袜| 亚洲欧美日韩另类精品一区二区三区| 欧美精品一区二区久久婷婷| 亚洲欧美在线一区| 欧美亚一区二区| 这里只有精品视频在线| 亚洲视频网站在线观看| 在线亚洲一区二区| 精东粉嫩av免费一区二区三区| 9国产精品视频| 蜜臀av国产精品久久久久| 一区二区三区在线不卡| 国产精品久久久久久久久借妻| 日韩视频在线永久播放| 欧美日韩亚洲精品内裤| 久久精品在线观看| 亚久久调教视频| 久久久99久久精品女同性| 一本久道综合久久精品| 欧美韩国在线| 国产裸体写真av一区二区| 欧美日本精品| 美女日韩在线中文字幕| 国产亚洲第一区| 欧美亚洲免费电影| 日韩亚洲欧美在线观看| 日韩视频在线一区二区| 亚洲国产天堂网精品网站| 免费观看久久久4p| 亚洲成在人线av| 欧美看片网站| 久久久999精品视频| 国产精品乱码人人做人人爱|