世界新动态:小试Blazor——实现Ant Design Blazor动态表单
时间:2023-06-25 06:30:06来源:博客园

前言

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

标签:

生活指南
  • 发挥好服务业稳定器作用 看热讯

    服务业是国民经济发展的“稳定器”和“助推器”,对经济增长的贡献率于

  • 世界即时看!除湿气的小妙方_除湿气最好的方法有哪些

    1、食疗祛湿食疗可以有效去除湿气,且方便又实用。2、建议在日常的饮食

  • 巨头3M因污染环境赔740亿元:部分产品极难降解,进血液会长久积存 天天时快讯

    化工巨头3M公司周四盘后宣布,同意支付最高可达125亿美元的和解金,以

  • 浙江临安:乡贤人才齐聚力 共富菜园再升级

    6月22日,又是一年端午节。2023“潮创浙西·聚力共富”龙井峡漂流狂欢

  • 焦点讯息:揭阳打造“心适小屋”筑牢市民心灵“防护墙”

    记者日前从揭阳市政府获悉,一年多来,揭阳市委政法委通过积极探索,结

  • 【整活向】第五人格X赛尔号:新监管者——“团长”_天天百事通

    当人们等待着黑暗散去之时、当人们期盼着美好未来之时,佩德藏在光明无

  • 世界微速讯:超卓航科(688237.SH):497.43万股限售股7月3日起上市流通

    格隆汇6月21日丨超卓航科(688237 SH)公布,公司本次上市流通的限售股东

  • 威孚高科(000581.SZ)拟10股派1元 于6月30日分红-世界热议

    智通财经讯,威孚高科(000581 SZ)公告,公司2022年年度权益分派拟:向

  • 环球新动态:四代篮球人见证“村BA”发展变迁

    新华社贵阳6月20日电(记者蒋成)“我的身体还硬朗,如果可以,我还想

  • 龙虎风云会的武功排名 天天报道

    1、第一名:横推八百无对手轩辕重出武圣人于和,书中的武林第一把交椅

  • 每日热议!吴淞创新城建设提速,百年纺织厂蝶变“时尚+科技”产业高地

      加快南北转型,是振兴上海老工业基地、构建城市发展新格局的战略之

  • 2023广州黄埔区汽车补贴多少钱一辆?

    为全面落实省、市强经济、促消费政策措施,进一步激发黄埔区夜间经济全

  • 日本强行排污入海,后果有多可怕?-全球最资讯

    国内起义,国外抗议,不管这里里外外的的反对声有多大,终究还是没拦住

  • 热文:“去美元化”或已不可逆转

    徐秀军(中国社会科学院世界经济与政治研究所研究员)  当前,全球“

  • 黄金走势分析最新消息(2023年6月16日)-每日信息

    基本消息面周五(6月16日),现货黄金短线突然快速上升,金价刚刚突破196

  • 印尼羽毛球公开赛混双1/4决赛:冯彦哲/黄东萍逆转击败德沙组合,挺进半决赛!_世界动态

    本场比赛,冯彦哲 黄东萍逆转战胜德差波 沙西丽,晋级四强,让人看得热

  • 民生
    • 唐伯虎什么生肖(唐伯虎是什么生肖?)

    • 每日观点:蓝山DHT-PHEV亮相深圳车展,超高产品力获市场持续关注

    • 世界观速讯丨儋州二手房投资讲解,普天豪苑二手房能不能升值?

    • AI代写论文,该不该管?-环球报资讯