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

首頁 > 互聯網

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

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

前言

最近想了解下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動態表單

天天快資訊:索尼PS5串流掌機價格來了:2100元 好像不貴

江淮A5 PLUS正式上市 售價6.58-8.58萬元

廈門今起三天悶熱潮濕 局部多雷陣雨

最新研究:史前時期地球每天時長僅19小時

端午假期最后一天 公路返程迎來峰值時段-世界聚焦

強鏈延鏈贏得發展主動權——訪恒力集團董事長、總裁陳建華|每日速訊

雄安新區營造一流營商環境

焦點快看:普京下令平叛 瓦格納指揮官受刑事調查

“五年來最火端午”大數據:這些城市最熱門 全球視點

呼聲與回應|業主擔心涇陽奧園譽景灣不能如期交房,施工進度看這里

鯇魚是什么魚一般超市能買到嗎-天天日報

速度超過飛機,冒著綠光…成都夜空現UFO?科普博主回應→|世界時訊

環球通訊!普京發表電視講話說將采取果斷行動穩定局勢

【天天熱聞】聯合國人權高專辦呼吁在蘇丹和乍得之間建立人道主義走廊

環球通訊!0-2到3-2!張本美和驚天大逆轉,淘汰名將進決賽,爭奪女單冠軍

WTT突尼斯挑戰賽最新戰報!國乒5項目只剩男單獨苗|環球訊息

男籃開啟新集訓 喬帥瞄準奧運門票-今日熱搜

【環球快播報】俄媒:俄南部軍區位于羅斯托夫的總部大樓被“瓦格納”成員包圍

今日熱門!共赴一場云上梯田夢想紅河的美麗之約

環球速遞!沈陽6.1萬余中考生今日赴考場

萬能鹵汁配方大公開,分享鹵雞腿雞蛋的家常做法

內飾迎調整,新款星途凌云官圖發布 天天快播

浙江龍游發生5車追尾事故,致6人死亡 全球短訊

羅馬諾:曼聯不會尋求巴黎圣日耳曼姆巴佩和內馬爾的交易 世界熱推薦

視頻|看尼山 夜空璀璨 環球今日報

漢中仙毫特點 漢中仙毫種類

東江湖水潤資興_精彩看點

世界熱議:風吹十里荷花香 “蓮”通鄉村“致富路”

全球看點:農村籍高校畢業生的就業選擇,有何特點?


主站蜘蛛池模板: 黄色三级中文字幕| 久久精品国产v日韩v亚洲| 欧美亚洲国产日本| 日本午夜在线亚洲.国产| 91精品视频观看| 国产偷久久久精品专区| 日韩欧美亚洲日产国| 久久久久免费精品| 免费看成人午夜电影| 欧美综合在线第二页| 一区二区在线中文字幕电影视频| 91免费精品视频| 国产美女在线精品免费观看| 久久视频在线观看中文字幕| 日本一区二区三区在线视频| 日韩中文字幕av在线| 亚洲a级在线观看| 伊人久久大香线蕉精品| 国产精品一区在线播放| 久久久精品日本| 日韩av高清| 欧美日韩精品免费在线观看视频| 91国产在线播放| 国产精品aaaa| 91久久久久久久一区二区| 麻豆成人av| 欧美日本韩国一区二区三区| 欧美亚洲精品日韩| 欧美精品在线第一页| 久久精品99国产| 精品国偷自产在线视频99| 国产专区在线视频| 国产在线精品自拍| 国产精品国产三级国产专播精品人| 亚洲综合精品伊人久久| 自拍日韩亚洲一区在线| 日韩中文字幕三区| 日本一区二区三区四区在线观看 | 亚洲综合一区二区不卡| 亚洲专区中文字幕| 日韩一级特黄毛片|