国产香港一级毛片在线看_人人看人人爽91视频_99久久er这里只有精品17_国产日产欧美a一级在线

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

天天快看點丨小試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倉庫

關鍵詞:

相關閱讀

国产香港一级毛片在线看_人人看人人爽91视频_99久久er这里只有精品17_国产日产欧美a一级在线

      国产日韩欧美a| 有码一区二区三区| 亚洲va国产天堂va久久en| 日韩一区二区三免费高清| 亚洲免费在线观看视频| 韩国av一区二区三区四区| 国产欧美视频一区二区| 欧美天天综合网| 亚洲国产精品精华液2区45| 日本vs亚洲vs韩国一区三区二区 | eeuss鲁一区二区三区| 亚洲精品免费在线| 日韩欧美视频一区| 亚洲国产欧美在线| 91在线播放网址| 色哟哟亚洲精品| 国产精品嫩草久久久久| 国产在线不卡一卡二卡三卡四卡| 中文字幕免费不卡在线| 欧美日韩免费观看一区三区| 1024国产精品| 成人免费毛片app| 亚洲国产另类av| 国产欧美日韩麻豆91| 激情五月婷婷综合网| 日韩一区在线免费观看| 日韩一区二区三区视频在线观看| 亚洲在线视频一区| 91久色porny| 欧美三级资源在线| 亚洲精选免费视频| 白白色 亚洲乱淫| 一本色道亚洲精品aⅴ| 中文字幕日韩av资源站| 国产成人鲁色资源国产91色综| 亚洲综合成人在线| 国产精品少妇自拍| 盗摄精品av一区二区三区| 午夜精品一区二区三区电影天堂| 亚洲国产精品精华液ab| 国产不卡在线一区| 91久久精品国产91性色tv| 亚洲三级免费观看| 久久婷婷成人综合色| 欧美肥妇bbw| 日本中文在线一区| 亚洲欧美一区二区不卡| 国产午夜精品一区二区三区视频| 国产一区二区剧情av在线| 亚洲资源在线观看| 亚洲视频一区在线观看| 2欧美一区二区三区在线观看视频| 欧美日韩国产系列| 日韩电影在线观看一区| 亚洲视频在线一区| 国产精品日产欧美久久久久| 白白色亚洲国产精品| 欧美色精品在线视频| 午夜精品国产更新| 亚洲美女在线国产| 中文字幕一区二区三区精华液| 99久久久国产精品| 欧美一二三在线| 国产永久精品大片wwwapp| 一本色道久久综合亚洲精品按摩| 亚洲影视在线播放| 1024亚洲合集| 中文字幕一区不卡| 久久久国产精品午夜一区ai换脸| 日韩欧美高清在线| 国产成人啪免费观看软件| 欧美性一二三区| 日本成人在线看| 午夜精品一区在线观看| 亚洲成人精品影院| 亚洲综合无码一区二区| 亚洲免费色视频| 国产精品国产三级国产专播品爱网| 久久精品亚洲精品国产欧美kt∨| 成人av在线播放网址| 欧美一区二区高清| 国产白丝网站精品污在线入口| 欧美日韩国产另类不卡| 久久 天天综合| 欧美午夜精品久久久久久超碰| 日韩精品乱码av一区二区| 亚洲一区二区在线免费观看视频| 亚洲综合色噜噜狠狠| 亚洲天堂久久久久久久| 亚洲裸体xxx| 亚洲六月丁香色婷婷综合久久| 最好看的中文字幕久久| 国产欧美一区二区精品性色| 中文字幕av一区二区三区| 国产日产精品1区| 国产精品三级av| 国产精品久久精品日日| 亚洲三级理论片| 一区二区三区在线免费| 亚洲第一av色| 午夜视频一区二区| 美女视频黄免费的久久 | 午夜亚洲国产au精品一区二区| 亚洲成人在线免费| 色综合久久精品| 精品一区二区三区在线播放视频| 欧美日韩免费一区二区三区视频| 国产精品影视在线观看| 日韩一区二区三区在线观看| 成人免费视频网站在线观看| 精品播放一区二区| 久久夜色精品国产噜噜av| 亚洲国产精品v| 中文字幕色av一区二区三区| 亚洲美女视频在线观看| 亚洲制服丝袜av| 青青草国产精品亚洲专区无| 欧美日韩高清在线播放| 成人深夜视频在线观看| 久久久久久久久免费| 中日韩免费视频中文字幕| 一区二区三区日韩欧美| 亚洲成年人网站在线观看| 久久成人综合网| 日韩欧美久久久| 久久九九久精品国产免费直播| 中文字幕一区不卡| 亚洲国产精品麻豆| 国产又黄又大久久| 精品粉嫩超白一线天av| 国产精品美女久久久久久| 亚洲成人手机在线| 欧美亚洲日本一区| 不卡一二三区首页| 国产精品高潮呻吟| 午夜精品福利一区二区蜜股av| 国产综合久久久久久鬼色| 精品国产麻豆免费人成网站| 国产精品婷婷午夜在线观看| 亚洲成人久久影院| 欧美人与性动xxxx| 久久久精品国产99久久精品芒果 | 久久精品亚洲乱码伦伦中文| 国产精品国产三级国产普通话99 | 欧美日韩国产影片| 久久综合国产精品| 亚洲综合精品自拍| 欧美猛男超大videosgay| 久久综合色播五月| 亚洲一区二区中文在线| 欧美日韩三级在线| 久久久91精品国产一区二区精品| 亚洲电影在线免费观看| 欧美精品粉嫩高潮一区二区| 久久精品在线免费观看| 午夜久久久久久久久| 日韩一区二区三区观看| 国产精品福利一区| 精品一区二区影视| 欧美国产精品一区二区三区| 亚洲国产一区二区视频| 国产原创一区二区三区| 中文字幕av一区 二区| 一本色道久久综合亚洲91| 99精品久久久久久| 午夜久久久久久电影| 日韩免费电影网站| 亚洲女厕所小便bbb| 国产精品综合在线视频| 国产精品久久久久久一区二区三区| 婷婷综合另类小说色区| 99re热视频这里只精品| 亚洲第一精品在线| 26uuu精品一区二区| 亚洲一级二级在线| 99久久精品国产精品久久| 亚洲第一搞黄网站| 2014亚洲片线观看视频免费| 亚洲制服丝袜av| 99久久er热在这里只有精品15 | 日韩一级完整毛片| 亚洲人成影院在线观看| 国产麻豆午夜三级精品| 亚洲视频小说图片| 91精品欧美一区二区三区综合在| 1区2区3区欧美| 成人性生交大片免费看中文 | 欧美一级免费观看| 一区二区三区精品在线观看| 成人国产在线观看| 五月激情综合色| 国产亚洲欧美日韩日本| 在线观看一区二区视频| 国产精品久久久久久久久免费桃花 | 欧美日韩午夜影院| 亚洲三级在线播放| proumb性欧美在线观看| 日本午夜精品视频在线观看| 国产欧美精品在线观看| 91豆麻精品91久久久久久|