首页 > 动漫

小试Blazor——实现Ant Design Blazor动态表单-天天快看点

来源:博客园 时间:2023-06-25 07:05:53

前言

最近想了解下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动态表单-天天快看点

环球快消息!沈阳铁路局王占柱处长(沈阳铁路局王占柱)

世界百事通!轩辕剑汉之云图文完美攻略(轩辕剑汉之云)

世界热推荐:捷豹路虎中国和捷豹路虎宁波召回车辆 凸轮轴支架机油油道未钻通

一考生查分 全家一起喊出666 应该可以冲复旦和交大! 环球热议

方坑岭影视基地签约!《老炮敢死队》后天开机

山东黄金集团推广开展典型案例解剖式调研、“代入式”调研经验做法

曝具俊晔回韩国,留大S独自面对风波,谁是真爱与汪小菲对比明显

强链延链赢得发展主动权——访恒力集团董事长、总裁陈建华|当前播报

杭州萧山亚运志愿平台正式启用

中央气象台6月25日06时继续发布暴雨黄色预警

世界报道:黄浦区将规划布局“两点一线” 打造外滩法律服务集聚带

仅4人踢遍五大联赛:拉杜乔尤&鲍尔森&约维蒂奇&小克鲁伊维特_天天精选

环球报道:我爸是李钢案件详情(我爸是李刚造句)

咕噜小天使完美存档_咕噜小天使修改器_快播报

乌苏市气象台发布雷电黄色预警[Ⅲ级/较重] 【2023-06-24】

世界最新:俄媒:俄南部军区位于罗斯托夫的总部大楼被“瓦格纳”成员包围

ChatGPT 六大劲敌:技术狂热者、天才 95 后、硅谷人脉王

最新:“十四运”交出高分答卷

谷歌或将其Pixel手机部分生产转移到印度

Theshy送出关键节奏,BLG远古龙怒斩WBG!Poke阵容下次真别玩了

6-3,6-4!阿尔卡拉斯横扫继续前进,生涯首进草地赛事决赛

天天新消息丨沙特阿美与道达尔能源授予110亿美元沙特石化设施扩建项目合同

瓦格纳创始人被诉武装叛乱,俄国民警卫队中央区军官进入紧急状态|世界视讯

全球速看:推动品牌建设上台阶

全球通讯!国际范儿,龙舟“划”向世界!端午节已成全人类共同文化遗产

世界新动态:中国女排遭遇升级版挑战

百事通!国内首条跨省轨交系统无感换乘线路开通

端午假期交通部门加强多种出行方式联动 热点

柿饼不能和什么东西一起吃(柿子饼不能和什么一起吃)-世界快报