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

前言

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

标签:

生活指南
  • α-烯基磺酸钠商品报价动态(2023-06-24)|当前简讯

    交易商品牌 产地交货地最新报价α-烯基磺酸钠 工业级,白色粉末东营市

  • 返程小心风雨!深圳全市雷电预警,北方酷热南方雨雨雨,欢迎小伙伴来广东避暑……_每日消息

    今天是端午假期最后一天经历了假期第一天的烈日当空第二天的雷电阵雨今

  • “九头鸟”文旅创意 评选再次启动 最高奖励10万元_全球视讯

    “九头鸟”文旅创意评选再次启动最高奖励10万元---楚天都市报极目新闻

  • 天天热资讯!陵水最便宜的房价,香水国色对比碧海一家·名城房价哪个便宜?

    陵水最便宜的房价,香水国色对比碧海一家·名城房价哪个便宜?海南陵水

  • 当前热文:如何才能好好爱自己?女性保养大全,让你更自信!

    如何才能好好爱自己?这是一个非常重要的问题,尤其是对于女性来说。女

  • 比亚迪s9上市时间_比亚迪S9多少钱 全球球精选

    问题:想问问大家,比亚迪S9多少钱?现在的车款式很多,但是不知道比亚

  • 环球微速讯:【拉片/理论分析】关于叶子彩虹糖之间的感情关系和细节

    我来投个大型安利 昨晚大晚上心血来潮决定给大家安利叶彩(其实是

  • 天天观天下!陈梦首次回应恋爱传闻!公开队友间关系!樊振东:留出空间 相互尊重

    陈梦首次回应恋爱传闻!公开队友间关系!樊振东:留出空间相互尊重,陈

  • 天津月内两度调整住房公积金政策 异地公积金贷款购房利好来了?_环球要闻

    2023年尚未过半,随着楼市“小阳春”出现降温,各地提振楼市消费的力度

  • 京东养车与中国石油北京销售公司达成合作 将打造双品牌标杆门店 天天快看点

    6月16日,京东养车与中国石油北京销售公司在北京大兴区中国石油鑫邦达

  • 全球快播:四川甘孜州令人迷恋的小众景点,美得像一滴绿眼泪,关键是不收费

    很多人听说过“此生必驾318”,你可知道G317的风景和318比起来毫不逊色

  • 世界微动态丨秦川大厨存在重大债务违约 公司处于停产状态

    挖贝网6月21日,秦川大厨(873598)的持续督导主办券商开源证券近日发

  • 宁夏:到2025年底实现基本养老服务制度基本健全 环球关注

    中新网银川6月21日电 (记者 杨迪)记者21日从宁夏民政厅获悉,日前

  • 六招!带你了解产业地产调研技巧

    在产业地产领域,实地调研是至关重要的。而在调研的过程中,采用正确的

  • 碧江:驻村帮扶再接力 乡村振兴谱新篇

    铜仁市碧江区始终把抓实驻村帮扶工作作为抓党建促乡村振兴的“关键一招

  • 湘乡:吹响2023年灌区清於扫障集结号

    为确保灌区农业灌溉用水需求,科学防范旱涝极端天气,全力保障灌区渠系

  • 民生
    • 天天即时看!市场下行对于价值投资来说是好事还是坏事?

    • 200万韩币等于多少人民币2021_200万韩币等于多少人民币

    • 德恩精工:实控人拟减持公司不超1.83%股份-环球快播

    • 环球微资讯!柯云路坦然应答“胡万林事件”—我寄希望于时间_关于柯云路坦然应答“胡万林事件”—我寄希望于时间概略