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

您的位置:首頁>新聞 > 業界 >

天天快看點丨小試Blazor——實現Ant Design Blazor動態表單

2023-06-25 08:03:29    來源:博客園

前言

最近想了解下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 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,午夜国产欧美理论在线播放,国产精品影视天天线,国内自拍亚洲
国产精品久久久久aaaa九色| 亚洲第一黄色网| 亚洲精品视频在线| 午夜精品美女自拍福到在线| 欧美日韩午夜在线| 国产乱码精品一区二区三区不卡| 久久久99久久精品女同性| 亚洲三级网站| 一级成人国产| 狠色狠色综合久久| 欧美日韩成人激情| 欧美精品一卡| 国产一区二区三区久久悠悠色av| 国产真实久久| 欧美日韩一二三区| 国产精品区一区二区三区| 伊人久久大香线蕉综合热线| 国产精品国产a| 国产日韩三区| 欧美精品情趣视频| 欧美在线二区| 欧美一区二区三区免费视频| 欧美国产激情| 久久99伊人| 亚洲自拍啪啪| 尤物视频一区二区| 国产精品大片免费观看| 伊人久久av导航| 亚洲图片激情小说| 亚洲福利视频在线| 国产日本欧美在线观看| 欧美激情综合网| 午夜精品久久久久久久久久久| 欧美一区二区播放| 亚洲激情一区| 裸体丰满少妇做受久久99精品| 久久综合电影| 欧美成人免费全部观看天天性色| 欧美日韩国产成人| 精品va天堂亚洲国产| 在线观看一区二区精品视频| 亚洲一区国产精品| 国产精品久久77777| 亚洲大片一区二区三区| 欧美与欧洲交xxxx免费观看| 久久精品亚洲| 欧美一区二视频| 在线日韩中文| 欧美一区二视频在线免费观看| 欧美日韩亚洲一区| 亚洲性感激情| 欧美激情精品久久久久久变态| 欧美日韩国产精品自在自线| 亚洲国产另类 国产精品国产免费| 亚洲国产成人在线播放| 国产麻豆精品久久一二三| 欧美一区二区精品在线| 亚洲一区二区三区精品在线观看| 国产三级精品三级| 亚洲毛片av在线| 老巨人导航500精品| 亚洲一区二区黄色| 久久人人97超碰人人澡爱香蕉| 欧美在线免费视屏| 国产精品一区免费视频| 亚洲乱码日产精品bd| 嫩草成人www欧美| 国产在线一区二区三区四区| 日韩亚洲视频在线| 日韩一级精品视频在线观看| 99精品欧美一区二区蜜桃免费| 久久久久国产精品厨房| 久久综合久久久| 在线观看欧美一区| 亚洲欧美不卡| 伊人一区二区三区久久精品| 一本色道久久综合亚洲二区三区| 欧美日韩国产综合视频在线观看| 欧美区日韩区| 亚洲午夜精品久久久久久app| 巨乳诱惑日韩免费av| 亚洲欧美在线播放| 日韩系列欧美系列| 久久久久久久久伊人| 亚洲大片一区二区三区| 伊人成年综合电影网| 免费成人高清在线视频| 欧美精品1区2区| 国产日韩欧美夫妻视频在线观看| 国产精品高潮呻吟视频| 国产精品红桃| 一本色道久久综合亚洲精品不卡| 激情久久影院| 欧美aⅴ99久久黑人专区| 欧美xxxx在线观看| 国产精品日本欧美一区二区三区| 久久久水蜜桃| 欧美激情小视频| 日韩午夜电影| 欧美成年人网站| 免费成人毛片| 久久国产精品黑丝| 一区二区三区你懂的| 国产精品拍天天在线| 欧美精品播放| 国产日韩综合一区二区性色av| 国产精品视频你懂的| 国产精品免费在线| 欧美风情在线观看| 欧美精品在欧美一区二区少妇| 一区二区三区高清在线| 亚洲三级免费观看| 欧美成人午夜免费视在线看片| 亚洲人成小说网站色在线| 欧美日韩一区二区三区四区五区| 最新热久久免费视频| 国产乱理伦片在线观看夜一区| 亚洲第一在线综合网站| 一本色道久久综合一区| 久久高清免费观看| 欧美性猛交一区二区三区精品| 久久日韩粉嫩一区二区三区| 亚洲午夜久久久| 久久久一区二区| 在线视频观看日韩| 久久不射2019中文字幕| 欧美日韩在线观看一区二区三区| 亚洲欧美日韩中文在线制服| 亚洲一级网站| 欧美日韩蜜桃| 黄色亚洲大片免费在线观看| 午夜视频在线观看一区二区| 精品1区2区| 欧美在线免费视屏| 欧美国产日韩精品免费观看| 韩国精品主播一区二区在线观看| 欧美成人免费小视频| 欧美日韩午夜视频在线观看| 国产在线麻豆精品观看| 国产精品久久久久久久午夜片| 亚洲视频你懂的| 这里只有精品电影| 亚洲日本aⅴ片在线观看香蕉| 国产精品videosex极品| 欧美国产日韩一二三区| 欧美性理论片在线观看片免费| 亚洲精品久久久久中文字幕欢迎你| 久久精品综合一区| 亚洲最新视频在线| 久久久久久久一区二区三区| 欧美日韩三区四区| 亚洲精品美女在线观看| 久久免费精品日本久久中文字幕| 欧美成人小视频| 亚洲深夜福利在线| 亚洲乱码久久| 精品成人国产| 久久久久9999亚洲精品| 欧美成人午夜| 欧美—级a级欧美特级ar全黄| 亚洲第一精品久久忘忧草社区| 亚洲第一综合天堂另类专| 国产欧美在线观看一区| 亚洲第一级黄色片| 久久久久91| 亚洲激情网站免费观看| 久久成人综合视频| 99国产精品视频免费观看一公开| 欧美性生交xxxxx久久久| 亚洲图片在线观看| 欧美成人高清| 西西裸体人体做爰大胆久久久| 欧美日韩在线免费视频| 亚洲三级色网| 久久久久一区二区三区四区| 亚洲一区二区三区四区五区黄| 国内精品伊人久久久久av一坑| 久久精品一级爱片| 久久久久久久久久看片| 在线观看成人小视频| 国产精品a久久久久久| 亚洲影音先锋| 欧美久久影院| 激情欧美一区二区三区在线观看| 欧美麻豆久久久久久中文| 久久青青草原一区二区| 亚洲欧洲精品一区二区精品久久久| 久久精品水蜜桃av综合天堂| 国内精品久久久久影院优| 亚洲特色特黄| 伊人久久男人天堂| 国产一区二区三区久久久久久久久| 久久国产精品99国产精| 国产精品九九久久久久久久| 欧美在线欧美在线| 亚洲大片精品永久免费| 国产一区二区三区网站| 亚洲精品欧美极品| 久久99伊人| 午夜免费在线观看精品视频|