世界热讯:小试Blazor——实现Ant Design Blazor动态表单
时间:2023-06-25 08:44:01来源:博客园

前言

最近想了解下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写一个简单的低代码框架,

  • 世界新动态:西安经开区举办西安市“新征程、再出发”应急诗歌诵读暨安全文化演出活动

    今年6月是第22个“安全生产月”,近日,围绕主题“人人讲安全、个个会

  • 成为网红之后

    成为网红之后

  • 倒计时2天 尼山前瞻丨向善?趋利?当儒家学说碰撞人工智能 古老文明或可解答未来焦虑-世界快播

    舜网山东频道是山东新闻权威发布平台,及时发布山东17地市新闻。

  • 当前热议!旭辉控股、旭辉永升服务:正制定行动方案以符合复牌指引,继续停牌

    6月23日,旭辉控股(集团)有限公司(00884 HK)和旭辉永升服务集团有限

  • 送给文艺男生最适合的礼物:从零开始学习如何用鹅毛笔写字

    你需要的东西羽毛笔书法墨汁平板纸羽毛笔是由鸟羽毛制成的,是古代

  • 如何煲机煲耳机有什么方法_如何煲机煲耳机有哪些方法-环球精选

    1、好耳机需要烧:好耳机需要烧。这里说的“焦”,简单来说,对于刚买

  • 自带穷相的人,开口就是这三种话,需要改正

    如果你遇到了很懒的人,肯定会有这样的情况发生:一个宿舍的人都在睡懒

  • 围城这本书主要讲了什么 焦点热闻

    《围城》是钱钟书先生创作的一部长篇小说,以离群索居的主题为中心,描

  • 游侠客旅游网官网app_游侠客旅游官网-百事通

    1、挺不错,通过这个旅游网旅游的话不仅可以欣赏到独特的美景,而且还

  • 爱自己的100种方式触发方法 全球资讯

    爱自己是终生浪漫的开始,我们需要花费多久的时间才能真正理解这句话的

  • 用于高对映选择性有机反应的新型手性催化剂研究_关于用于高对映选择性有机反应的新型手性催化剂研究介绍

    用于高对映选择性有机反应的新型手性催化剂研究,关于用于高对映选择性

  • 世界热消息:全国中成药集采药品拟中选结果公布,平均降幅达49.36%

    全国中成药采购联盟集中带量采购近日公布拟中选结果:68个品规药品中选

  • 最高级别!北京发布高温红色预警!该如何防范?|即时看

    2015年实施修订后的高温预警信号标准以来,北京首次发布高温红色预警。

  • 世界聚焦:控股股东未按期还款 宋都集团存单累计被划扣15.71亿元

    6月21日,*ST宋都(600077 SH)发布公告称,因控股股东未按期还款,其

  • 退休副教授状告武汉作协原领导抄袭:连错误都抄,还把原作者写成“古人”

    退休副教授状告武汉作协原领导抄袭:连错误都抄,还把原作者写成“古人

  • 旅游
    • 关于茶的经典句子有哪些_关于茶的经典诗句

    • 柏林安卡拉体育_关于柏林安卡拉体育概略-当前观点

    • 当前滚动:弘业期货、南京人保首单财政补贴型 生猪期货价格保险成功赔付

    • 双清区2023年度人才发展大会举行_世界消息