久久精品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,午夜国产欧美理论在线播放,国产精品影视天天线,国内自拍亚洲
日韩视频在线一区二区三区| 欧美日韩国产小视频| 亚洲人成久久| 国产精品久久久久久久久久免费看| 国产日韩在线亚洲字幕中文| 欧美一区二区三区的| 在线精品一区二区| 极品尤物久久久av免费看| 欧美视频在线观看一区二区| 欧美一区二区三区四区视频| 永久免费毛片在线播放不卡| 欧美日韩精品伦理作品在线免费观看| 免费在线观看日韩欧美| 亚洲欧美一区二区激情| 国产精品久久久久影院亚瑟| 国模精品一区二区三区色天香| 久久亚洲欧美国产精品乐播| 91久久精品国产91久久性色| 久久精品人人做人人爽电影蜜月| 欧美大香线蕉线伊人久久国产精品| 亚洲人成网站777色婷婷| 国产欧美在线观看一区| 欧美精品手机在线| 亚洲电影观看| 一区二区三区**美女毛片| 欧美日韩一区二区三区在线视频| 欧美一区二区三区久久精品茉莉花| 欧美成人精品不卡视频在线观看| 一区二区三区高清| 亚洲精品久久久久久久久久久| 午夜一区不卡| 国产精品一二三视频| 免费短视频成人日韩| 老鸭窝91久久精品色噜噜导演| 一本久久综合亚洲鲁鲁五月天| 国产精品99一区二区| 欧美激情亚洲国产| 免费欧美在线视频| 欧美日韩国产经典色站一区二区三区| 宅男噜噜噜66国产日韩在线观看| 亚洲国产精品久久| 在线观看国产欧美| 在线视频观看日韩| 国产精品自在线| 午夜精品久久| 欧美一区二区在线看| 韩国一区二区三区美女美女秀| 亚洲在线电影| 欧美一区二区在线视频| 亚洲级视频在线观看免费1级| 亚洲看片一区| 一区二区三区日韩欧美精品| 中文一区在线| 亚洲欧美美女| 欧美成人精品影院| 美女在线一区二区| 麻豆精品在线视频| 亚洲精品少妇| 亚洲国产三级网| 洋洋av久久久久久久一区| 国产精品毛片a∨一区二区三区|国| 麻豆视频一区二区| 免费在线欧美黄色| 欧美刺激午夜性久久久久久久| 欧美三级网页| 国产精品专区h在线观看| 一区二区三区在线免费播放| 国产精品久久久久久久久| 另类尿喷潮videofree| 玖玖视频精品| 欧美三级乱人伦电影| 亚洲一区二区在线免费观看| 狠狠久久五月精品中文字幕| 亚洲国产va精品久久久不卡综合| 中文在线资源观看视频网站免费不卡| 日韩视频一区二区三区| 欲香欲色天天天综合和网| 亚洲欧美日本伦理| 久久99伊人| 欧美亚洲在线观看| 久久精品99国产精品酒店日本| 久久国产精品久久久久久电车| 午夜精品久久久久99热蜜桃导演| 欧美国产视频一区二区| 国产精品日韩欧美大师| 亚洲电影中文字幕| 亚洲国产成人在线| 亚洲深夜福利| 欧美视频一区| 91久久国产综合久久蜜月精品| 亚洲黄页一区| 欧美在线观看网址综合| 亚洲国产你懂的| 欧美亚洲免费电影| 免费观看久久久4p| 国产精品免费视频观看| 国产情人节一区| 欧美精品国产一区| 黄色一区三区| 午夜视频久久久久久| 另类尿喷潮videofree| 伊人久久大香线蕉综合热线| 欧美精品乱人伦久久久久久| 精品999在线播放| 欧美在线视频播放| 国内精品免费在线观看| 亚洲精品久久久久久久久久久久| 亚洲午夜精品久久久久久浪潮| 欧美日本簧片| 妖精视频成人观看www| 欧美成人一区二免费视频软件| 亚洲国产成人精品女人久久久| 在线视频欧美一区| 国产精品jizz在线观看美国| 欧美成人精品一区| 国产亚洲毛片在线| 欧美一区二区三区免费观看视频| 一区二区电影免费在线观看| 欧美日韩免费在线| 亚洲天堂网在线观看| 久久久一二三| 久久久五月天| 一区二区三区福利| 欧美人与性禽动交情品| 一区二区三区在线免费播放| 欧美极品一区| 一区二区av在线| 国产在线欧美| 久久精品日韩| 亚洲国产精品美女| 久久久蜜桃一区二区人| 一区二区三区在线免费播放| 免费在线观看一区二区| 亚洲视频你懂的| 国产婷婷色一区二区三区在线| 亚洲韩国一区二区三区| 欧美亚洲不卡| 欧美亚洲一区| 亚洲人成网在线播放| 欧美成人乱码一区二区三区| 国产精品综合| 美女日韩在线中文字幕| 亚洲一区二区在线观看视频| 亚洲成色www8888| 久久久水蜜桃av免费网站| 国产精品99免费看| 99精品视频一区二区三区| 一区二区免费在线播放| 免费看成人av| 午夜亚洲福利| 亚洲视屏在线播放| 亚洲国产欧美日韩精品| 国产精品v片在线观看不卡| 最新国产乱人伦偷精品免费网站| 欧美激情导航| 欧美在线免费观看| 国产视频一区在线观看| 一本久久精品一区二区| 激情欧美亚洲| 激情欧美亚洲| 欧美日韩卡一卡二| 久久久久一本一区二区青青蜜月| 一本一本久久a久久精品综合妖精| 欧美日韩91| 欧美日韩色一区| 国产精品扒开腿爽爽爽视频| 亚洲欧美精品在线观看| 国产精品久久久久久久久借妻| 欧美另类69精品久久久久9999| 欧美高清影院| 免费在线看一区| 欧美片网站免费| 亚洲欧洲在线免费| 久久国产一二区| 亚洲视屏在线播放| 伊人色综合久久天天五月婷| 国产精品扒开腿爽爽爽视频| 国产精品99久久久久久宅男| 欧美日韩国产欧美日美国产精品| 美女脱光内衣内裤视频久久网站| 在线观看欧美激情| 国产精品专区h在线观看| 欧美日韩蜜桃| 国产精品美女视频网站| 欧美日韩国产色综合一二三四| 日韩一级免费| 欧美资源在线观看| 欧美成人精品福利| 欧美一区二区三区视频在线| 在线观看成人网| 亚洲春色另类小说| 国产在线乱码一区二区三区| 国产视频在线观看一区| 欧美性大战久久久久久久| 国产精品高潮呻吟| 欧美va亚洲va国产综合| 老司机67194精品线观看| 亚洲天堂av电影| 亚洲欧美在线另类| 久久精品久久99精品久久|