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

首頁 > 培訓

小試Blazor——實現Ant Design Blazor動態表單

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

前言

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

春天英文單詞怎么說(春天英文單詞) 全球訊息

兩派出所遭襲造成9人身亡,越南抓獲84名嫌疑人 世界看熱訊

滿嘴跑火車!女評論員稱雷迪克是平庸射手 后者反問:你認真的嗎|天天看熱訊

每日看點!端午假期最后一天 公路返程迎來峰值時段

今日熱門!以茶換油,伊朗和斯里蘭卡貿易避開美元

38歲女星法蘭琪一尸兩命!懷孕5個月發生車禍,同車2個兒子昏迷

好騷啊,這新機絕對是來搗亂的|焦點熱議

父親節蝴蝶結花束怎么做?|環球快播

一秒蝴蝶結頭發扎法?

北京中考語文作文題目出爐!“我讀到的北京”和“我生活中的一棵樹”二選一|全球時訊

【文體市場面面觀】鄉村賽事要平衡好“商味”和“村味” 世界觀天下

港交所雙柜臺模式亮相,業內:有利于更多資本流入港股|當前資訊

在銀行存定期存款,建議牢記“5不要”,以免損失本息

環球報道:突然猛漲!有人開車10多個小時連夜搶貨!網友懵了:比黃金還貴?

【有色金屬】能源金屬:5月碳酸鋰進口量環比減少10.64%,氫氧化鋰出口量環比增長8.62%

保護知識產權激發創新活力 世界觀速訊

Meta更新Quest固件,Quest 2與Quest Pro性能升級

當前播報:啟程薩格勒布!樊振東呆萌可愛,孫穎莎開心熱聊,王楚欽大牌傍身

Theshy送出關鍵節奏,BLG遠古龍怒斬WBG!Poke陣容下次真別玩了

打造“果旅融合”新路徑 小小百香果成為“致富果”“幸福果” 世界熱消息

小米畫過餅的PPT手機,今天終于回來了-全球觀焦點

重回積分榜榜首?BLG再迎強敵WBG,Theshy對戰Bin-天天快播

書字是什么結構的字體(書是什么結構)

環球微動態丨玩法“上新” “暑期檔”旅游持續升溫

【播資訊】保險公司的注冊資本需要多少-世界今日訊

太陽告別保羅時代!太陽老板歡迎比爾+強調要奪冠 曬老炮成就致謝-環球速看料

環球快報:世界信息:上海2022年退休工資調整細則

天天觀天下!民營企業法律風險防控提示書怎樣規定?


主站蜘蛛池模板: 久久精品小视频| 国产美女久久精品香蕉69| 亚洲视频导航| 黄色三级中文字幕| 亚洲国产精品毛片| 国产精品小说在线| 日本在线视频不卡| 欧美日韩午夜爽爽| 欧美日本韩国国产| 免费观看国产精品视频| 一区二区三区四区欧美| 99久久久精品免费观看国产| 午夜精品在线观看| 久久人人爽人人爽人人片av高请| 久久国产精品一区二区三区| 亚洲AV无码成人精品一区| 一区二区三区四区久久| 欧美综合激情网| 日本精品中文字幕| 日本高清视频一区二区三区| 91精品国产乱码久久久久久久久| 久久av在线播放| 中文字幕在线亚洲精品| 人妻久久久一区二区三区| 国产在线视频不卡| 国产精品美女免费视频| 欧美日韩大片一区二区三区| 欧美交换配乱吟粗大25p| 亚洲 国产 日韩 综合一区| 中文字幕在线观看一区二区三区| 久久福利视频网| 99视频在线免费观看| 激情综合网婷婷| 国产精品自拍合集| 日本视频久久久| 亚洲五码在线观看视频| 日本一区二区三区视频在线观看| 欧美人成在线视频| 色综合久久天天综线观看| 91精品国产高清久久久久久| 国产精品久久久久999|