久久精品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,午夜国产欧美理论在线播放,国产精品影视天天线,国内自拍亚洲
亚洲美女毛片| 一本一本大道香蕉久在线精品| 国产精品女人毛片| 国产区欧美区日韩区| 久久免费高清| 亚洲深夜福利| 卡通动漫国产精品| 一区二区免费看| 欧美一区二区三区四区在线观看| 久久嫩草精品久久久精品| 国产精品久久久亚洲一区| 亚洲国产婷婷香蕉久久久久久| 欧美视频免费看| 亚洲国产乱码最新视频| 欧美日韩一区二区三区| 欧美午夜无遮挡| 久久精品国内一区二区三区| 一卡二卡3卡四卡高清精品视频| 欧美三级乱人伦电影| 午夜视频一区在线观看| 伊人影院久久| 免费在线看成人av| 久久久亚洲综合| 99re热这里只有精品视频| 欧美在线看片a免费观看| 亚洲欧美日韩中文播放| 久久综合久久综合久久综合| 午夜精品一区二区在线观看| 美玉足脚交一区二区三区图片| 日韩图片一区| 娇妻被交换粗又大又硬视频欧美| 夜夜嗨av色一区二区不卡| 欧美va亚洲va日韩∨a综合色| 亚洲图片欧洲图片日韩av| 久久婷婷国产麻豆91天堂| 99re6这里只有精品| 老牛影视一区二区三区| 国产精品久久久久久久app| 亚洲欧美不卡| 国产精品视频免费在线观看| 嫩草伊人久久精品少妇av杨幂| 久久中文欧美| 国产视频丨精品|在线观看| 欧美资源在线| 新67194成人永久网站| 这里只有精品在线播放| 一区二区三区欧美| 久久亚洲风情| 久久综合狠狠综合久久激情| 国产精品看片你懂得| 夜夜嗨av一区二区三区| 在线观看欧美日韩国产| 国产精品你懂的| 最新国产拍偷乱拍精品| 激情久久中文字幕| 欧美高清视频一区二区三区在线观看| 国产在线精品成人一区二区三区| 精品成人国产| 久久福利精品| 久久久久九九九九| 久久精品成人一区二区三区蜜臀| 亚洲人成啪啪网站| 一区二区三区中文在线观看| 久久精品国产久精国产爱| 亚洲伊人伊色伊影伊综合网| 国产精品大片免费观看| 日韩西西人体444www| 99国产精品99久久久久久粉嫩| 韩国精品在线观看| 亚洲人精品午夜| 日韩亚洲视频| 亚洲人成精品久久久久| 久久久久久久波多野高潮日日| 久久午夜电影| 欧美综合国产精品久久丁香| 亚洲视频观看| 亚洲欧美日韩国产综合在线| 99v久久综合狠狠综合久久| 欧美电影在线播放| 欧美伦理在线观看| 欧美欧美天天天天操| 亚洲欧美日本视频在线观看| 亚洲欧洲一区二区三区| 免费在线看一区| 亚洲精品免费电影| 欧美一区午夜精品| 国产视频欧美视频| 欧美日本不卡| 国产一区二区毛片| 欧美三级资源在线| 国产亚洲精品久久久久婷婷瑜伽| 日韩一区二区精品葵司在线| 国产日韩专区在线| 亚洲精品国产品国语在线app| 极品裸体白嫩激情啪啪国产精品| 国产麻豆精品在线观看| 亚洲三级电影全部在线观看高清| 国产一区二区三区四区在线观看| 欧美久久婷婷综合色| 可以免费看不卡的av网站| 久久亚洲一区二区三区四区| 麻豆国产精品777777在线| 欧美成人dvd在线视频| 在线欧美三区| 美女主播精品视频一二三四| 国产日韩欧美综合精品| 亚洲欧美日韩一区二区在线| 久久精品亚洲精品国产欧美kt∨| 欧美亚洲自偷自偷| 妖精成人www高清在线观看| 欧美va日韩va| 韩国一区二区三区美女美女秀| 最新国产の精品合集bt伙计| aa国产精品| 欧美影院午夜播放| 亚洲欧美日韩爽爽影院| 亚洲欧美日韩一区二区在线| 久久亚洲精品欧美| 国产精品日韩精品| 欧美日韩性视频在线| 欧美日韩不卡一区| 男女激情视频一区| 99国产精品| 91久久综合| 久久免费精品日本久久中文字幕| 玖玖在线精品| 国产精品国产三级国产aⅴ9色| 久久久中精品2020中文| 欧美精品一二三| 在线观看日韩专区| 一本色道久久综合亚洲精品婷婷| 亚洲国产色一区| 国产一区日韩一区| 午夜精品久久久久久久99热浪潮| 亚洲精品国产拍免费91在线| 中文有码久久| 国产精品综合av一区二区国产馆| 欧美日一区二区三区在线观看国产免| 麻豆91精品91久久久的内涵| 久久九九全国免费精品观看| 国产精品视频久久一区| 欧美日韩黄视频| 亚洲精品偷拍| 久久riav二区三区| 久久女同互慰一区二区三区| 国产精品99一区| 国产一区欧美日韩| 免费影视亚洲| 黄色国产精品一区二区三区| 亚洲欧美日韩国产一区二区| 韩国三级在线一区| 亚洲女女女同性video| 亚洲韩国一区二区三区| 国产精品一区毛片| 国产亚洲a∨片在线观看| 国产精品免费在线| 国产美女一区| 久久精品视频导航| 欧美区二区三区| 亚洲综合色自拍一区| 欧美日韩一卡二卡| 国产精品激情| 欧美在线精品免播放器视频| 亚洲精品在线视频观看| 欧美 日韩 国产精品免费观看| 欧美精品18videos性欧美| 伊人成综合网伊人222| 亚洲欧美国产高清| 亚洲国产精品va| 欧美激情一区二区三区全黄| 日韩一级免费| 欧美天天视频| 久久精品国产亚洲高清剧情介绍| 国产精品久久久久久av福利软件| 欧美日韩在线观看视频| 亚洲一区二区毛片| 欧美激情视频一区二区三区在线播放| 午夜激情亚洲| 久久精品一区蜜桃臀影院| 久久亚洲一区二区| 欧美吻胸吃奶大尺度电影| 久久综合婷婷| 欧美一区二区三区日韩视频| 国产精品久久一级| 久久天堂av综合合色| 国产精品久久久久久久久久免费看| 久久久精品一区| 激情欧美丁香| 亚洲精品中文字| 欧美成人在线影院| 亚洲午夜视频在线观看| 国产精品久久一卡二卡| 欧美大片va欧美在线播放| 欧美一区二区三区免费视| 亚洲国产成人久久综合一区| 欧美伦理91i| 国产精品美女久久久久久久| 久久精品亚洲精品国产欧美kt∨| 国产一区二区三区成人欧美日韩在线观看| 亚洲清纯自拍|