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

前言

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

    前言最近想了解下Blazor,于是尝试使用Blazor写一个简单的低代码框架,

  • “低价股群体”领跌变抗跌 掘金可选盈利与国资控股

    最近3个多月,过去两年风光无限的“超跌低价股”遭到重创。通达信数据

  • 今日播报!卧龙区七一街道中州社区:端午佳节 “粽”情重意

    全媒体记者陈向革通讯员李东在端午节到来之际,为弘扬传统文化,使辖区

  • 观察:中国经济信心说丨他们为什么纷纷投下“信任票”?

    近日,比尔·盖茨的访华之旅引发广泛关注。这是他第18次访华,也是时隔

  • win7(桌面) 今日热文

    来为大家解答以上问题,win7,桌面很多人还不知道,现在让我们一起来看

  • 水合硝酸镓

    1、水合硝酸镓是一种化学物质。2、分子式是Ga(NO3)3·xH2O。本文关于水

  • 出口坦桑尼亚,我国自主培育种鸡首次走出国门

    据农业农村部网站6月21日消息,近日,北京华都峪口禽业有限责任公司自

  • 2023年国际划联龙舟世界杯预赛在屈原故里湖北秭归开赛

    图为2023年国际划联龙舟世界杯比赛现场。本报记者董庆森摄图为2023年国

  • 车的暖风不热怎么回事(车暖风不热是怎么回事怎么解决) 环球新资讯

    一般来说,汽车暖风不热是因为冷却液温度达不到空调暖风的工作标准,暖

  • “中国温泉之乡”广东龙门启动“三伏浴”-天天热文

    惠州市龙门县是广东省乃至国内颇具规模的温泉旅游产业集聚区,也

  • 因赛集团拟定增募资不超6.45亿元 用于打造“营销版ChatGPT” 今热点

    中国品牌营销行业正在深度切入AIGC大模型。  因赛集团(300781)6月21

  • 湖北省图书馆招募10名暑期编外人员 每日报道

    【来源:湖北省图书馆】6月21日,湖北省图书馆发布关于招募少年儿童图

  • 土耳其将最低工资提高34%以应对通胀飙升-环球微头条

    【土耳其将最低工资提高34%以应对通胀飙升】路透社6月20日报道,土耳其

  • 马云指出淘宝天猫未来三个方向 应提供更好的服务_全球今亮点

    近日,马云在淘天集团的一次会议上提醒高管们,当前淘天集团所处的

  • 环球观焦点:AI创企“生数科技”完成近亿元天使轮融资

    36氪获悉,近日AI创企“生数科技”完成了近亿元的天使轮融资。本轮融资

  • 天天观焦点:降息了 居民手头的“闲钱”流向保险、黄金

    作者:陈君君在银行下调存款利率后,6月15日,中期借贷便利(MLF)利率

  • 旅游
    • 中证指数公司:发布中证农银乡村振兴指数-环球要闻

    • 五部门:引导金融机构加大对乡村振兴重点领域信贷支持力度_世界头条

    • 浙江省绍兴市越城区坡塘村——山乡吹来艺术风 快报

    • 【天天时快讯】中国航天刷新多星测控纪录