国产美女主播视频一区_国产精品蜜臀在线观看_亚洲成人动漫一区_亚洲视屏在线播放

首頁 > 美食

今日播報!小試Blazor——實現Ant Design Blazor動態表單

來源:博客園 時間:2023-06-25 07:30:26

前言

最近想了解下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倉庫

相關稿件

今日播報!小試Blazor——實現Ant Design Blazor動態表單

大學獎學金申請理由(獎學金申請理由300 500) 熱資訊

天天滾動:綠軍送走斯瑪特 帕金斯直呼不理解 杰弗森安慰:木已成舟了

薪資專家:湖人不會追歐文 他們專注于留住里夫斯和八村塁-每日播報

2023年4月別克GL8銷量多少? 在美系車中排名怎么樣?

斯瑪特發文向波士頓告別:雖未拿到第18冠但無比驕傲

局地氣溫達40℃!中央氣象臺繼續發布高溫橙色預警

曝具俊曄回韓國,留大S獨自面對風波,誰是真愛與汪小菲對比明顯|天天微速訊

世界關注:3000左右的手機推薦(3000左右的手機推薦2019)

業務員工作總結報告(業務員工作總結) 世界熱推薦

李想,在微博“造車”

“敬禮娃娃”郎錚637分!已收到北大、人大邀請-世界資訊

我的輸入法是什么(我的輸入法無法使用 怎么辦)

顯存不足會怎么樣(顯存不足)

將9月底實現量產 全新一代北京BJ40申報圖

伊能靜罕曬兒女同框照,哈利從美國放假回國|今日關注

全球聚焦:儋州考生 中考期間遇到突發狀況怎么辦?不慌!這里有應對大全

玩逆戰游戲太卡什么原因(玩逆戰不流暢怎么辦)

后風窗玻璃刮水器及洗滌器圖標(前風窗玻璃刮水器及洗滌器圖標)|焦點報道

玩cf卡怎么辦解決方法(玩cf卡怎么辦)

巴基斯坦取消進口限制以滿足國際貨幣基金組織要求_今日熱文

【魅力競演·敘州】三等獎作品展播

心悅俱樂部g分有什么用(心悅g分有什么用)-天天資訊

市場下行對于價值投資來說是好事還是壞事?_每日熱訊

【環球時快訊】據俄羅斯衛星通訊社6月25日報道,俄羅斯總統普京已簽署新法令,宣布9月3日為對日本軍國主義戰爭勝利紀念日暨二戰結束紀念日

環球微速訊:端午假期河南旅游接待1266.3萬人次同比增長48.6%

突發!國泰航空一客機突發故障,11人逃生途中受傷送醫!女乘客還原驚恐一幕:有人打電話給父母一直哭,有一個媽媽抱著孩子一直說對不起……

通訊!歐盟通過第11輪對俄制裁,俄外交部:制裁非法,已及時回應

天天觀焦點:莘縣開展“粽享和諧鄰里情”活動

俄外長:俄白兩國均未違反《不擴散核武器條約》 環球熱門


主站蜘蛛池模板: 91精品在线影院| 国产美女搞久久| 日本国产一区二区三区| 久久久久久久久国产| 亚洲日本欧美在线| 国产精品国产三级国产专播精品人 | 91久久精品国产| 激情小说网站亚洲综合网| 日韩欧美视频一区二区三区四区| 国产不卡一区二区在线观看| 好吊色欧美一区二区三区视频| 人妻精品无码一区二区三区| 亚洲在线欧美| 中文字幕无码不卡免费视频| 国产精品国产精品国产专区不卡 | 国产精品狠色婷| 国产精品永久在线| 蜜桃视频成人在线观看| 日韩一区二区精品视频| 午夜精品视频在线观看一区二区 | 日韩精品视频久久| 日韩精品视频久久| 欧美日韩亚洲一区二区三区在线观看| 亚洲熟妇无码一区二区三区| 91精品国产91久久久久久不卡| 国产高清不卡av| 99福利在线观看| av日韩一区二区三区| 日本久久久精品视频| 日韩久久久久久久久久久久| 日韩成人av电影在线| 欧美激情在线一区| 久久精品日韩精品| 精品中文字幕乱| 国产精品入口福利| 成人国产精品日本在线| 一区二区三区四区不卡| 日本一区高清在线视频| 日韩在线第三页| 欧美激情亚洲国产| 国产日韩在线一区二区三区|