国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

小試Blazor——實現(xiàn)Ant Design Blazor動態(tài)表單

這篇具有很好參考價值的文章主要介紹了小試Blazor——實現(xiàn)Ant Design Blazor動態(tài)表單。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

前言

最近想了解下Blazor,于是嘗試使用Blazor寫一個簡單的低代碼框架,于是就采用了Ant Design Blazor作為組件庫

低代碼框架在表現(xiàn)層的第一步則是動態(tài)表單,需要將設(shè)計時的結(jié)構(gòu)渲染成運行時的表單,本次主要實現(xiàn)動態(tài)表單,相關(guān)數(shù)據(jù)接口都以返回固定數(shù)據(jù)的形式實現(xiàn)

實現(xiàn)

1.項目準備

先通過命令創(chuàng)建一個Ant Design Blazor項目,并加入到空的解決方案當中:

dotnet new antdesign -o LowCode.Web -ho server

?

由于我們需要寫一些API接口,所以在Startup類中加入控制器相關(guān)的代碼:

?

        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<NavigationManager>().BaseUri)
            });
            services.Configure<ProSettings>(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類并填入固定數(shù)據(jù),并在Startup類中注冊:

?

    public class MenuService
    {
        /// <summary>
        /// 獲取左側(cè)導(dǎo)航數(shù)據(jù)
        /// </summary>
        /// <returns></returns>
        public virtual MenuDataItem[] GetMenuData()
        {
            return new MenuDataItem[]
            {
                new MenuDataItem
                {
                    Path="/",
                    Name="測試模塊",
                    Key="Test",
                    Icon="smile",
                    Children=new MenuDataItem[]
                    {
                        new MenuDataItem
                        {
                            Path="/StdForm",
                            Name="動態(tài)表單",
                            Key="Form",
                            Icon="plus-square"
                        }
                    }
                }
            };
        }
    }

?

修改BaseicLayout.razor中@code部分,將_menuData改為從MenuService中獲?。?/span>

?

    private MenuDataItem[] _menuData ;
    [Inject] public MenuService MenuService { get; set; }

    protected override async Task OnInitializedAsync()
    {
        await base.OnInitializedAsync();
        _menuData = MenuService.GetMenuData();
    }

?

3.表單組件接口

創(chuàng)建一個簡單的表單與組件的Model:

錄入控件Input:

    public class Input 
    {
        public string Name { get; set; }
        public string Value { get; set; }
    }

?

標準表單StandardFormModel:

    public class StandardFormModel
    {
        public StandardFormModel()
        {
            ArrayInput = new List<Input>();
        }
        public List<Input> 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<Input>(){
                new Input()
                {
                    Name="賬號"
                },
                new Input()
                {
                    Name="密碼"
                }
            });
            return result;
        }
    }

  

4.動態(tài)表單頁面

在Pages文件夾下創(chuàng)建一個StdForm.razor和StdForm.razor.cs文件

StdForm.razor.cs(注意partial):

    public partial class StdForm
    {
        public StandardFormModel StandardFormModel { get; set; }

        public Form<StandardFormModel> StdFormModel { get; set; }

        [Inject]
        public HttpClient HttpClient { get; set; }
     public void Init() { var formStruc = HttpClient.GetFromJsonAsync<StandardFormModel>("api/Form/GetFormStruc").Result; StandardFormModel= formStruc; } protected override async Task OnInitializedAsync() { Init(); await base.OnInitializedAsync(); } }

  

StdForm.razor:

@page "/StdForm"
<Form @ref="StdFormModel"
      Model="StandardFormModel"
    LabelColSpan="1"
    WrapperColSpan="6">

    @foreach (var item in StandardFormModel.ArrayInput)
    {
        <FormItem Label="@item.Name">

            @if (item is Model.Component.Input)
            {
                <Input @bind-Value="@item.Value"/>
            }

        </FormItem>
    }

</Form>

  

運行效果

小試Blazor——實現(xiàn)Ant Design Blazor動態(tài)表單

?

總結(jié)

在Blazor項目中要訪問API接口則需要注入HttpClient類,使用HttpClient請求API接口即可,也可以直接注入Services調(diào)用。

目前僅僅是驗證了動態(tài)表單的可能性,其他的組件渲染可以根據(jù)Ant Design Blazor官方文檔定義模型結(jié)構(gòu)實現(xiàn)

參考文檔:

Blazor官方文檔

Ant Design Blazor官方文檔

Ant Design Blazor倉庫文章來源地址http://www.zghlxwxcb.cn/news/detail-498595.html

到了這里,關(guān)于小試Blazor——實現(xiàn)Ant Design Blazor動態(tài)表單的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • vue3中使用ant-design-vue的layout組件實現(xiàn)動態(tài)導(dǎo)航欄功能(1~2級)

    vue3中使用ant-design-vue的layout組件實現(xiàn)動態(tài)導(dǎo)航欄功能(1~2級)

    目錄 0 前言 1 準備工作 1.1 安裝ant-design-vue 1.2 安裝圖標組件包 2 選擇組件 3 路由文件 4 Vue導(dǎo)航頁面 5 最終效果 ????????最近在自己搞一個前后端小項目,前端想使用ant-design-vue的layout組件實現(xiàn)動態(tài)導(dǎo)航欄和面包屑,但是網(wǎng)上的資料較少,所以我就自己整合實現(xiàn)了一下,在此

    2024年02月15日
    瀏覽(27)
  • ant design pro + umi4的動態(tài)菜單與動態(tài)路由

    ant design pro + umi4的動態(tài)菜單與動態(tài)路由

    困擾我好多天的自定義菜單及路由終于完成了,首先雖然看似為一個功能,但在umi4中是兩項配置。 先說說我浪費了大量時間使用的處理方式:因為曾經(jīng)的項目是umi3的,所以我就想原樣搬過來,結(jié)果發(fā)現(xiàn),布局頁BasicLayout的子children不見了! ? ? 如果這個子路由能正常顯示,

    2024年02月11日
    瀏覽(22)
  • ant design pro v5 - 03 動態(tài)菜單 動態(tài)路由(配置路由 動態(tài)登錄路由 登錄菜單)

    1 動態(tài)菜單 ? ? ? ? 技術(shù)思路:配置路由,用戶登錄后根據(jù)用戶信息獲取后臺菜單。 2 動態(tài)路由+動態(tài)菜單 ? ? ? ? 技術(shù)思路: 使用umijs的運行時修改路由 patchRoutes({?routes?})??UMIJS 參考文檔?,react umi 沒有守護路由的功能 直接在 app.tsx? 的?layout 下的?childrenRender 添加守護路

    2023年04月09日
    瀏覽(19)
  • Ant vue中表單驗證(動態(tài)校驗、部分校驗)

    Ant vue中表單驗證(動態(tài)校驗、部分校驗)

    前提 :寫了超級復(fù)雜的表單,其中涉及了很多表單驗證的地方,現(xiàn)一一記錄一下; ant-vue 版本1.7.8 vue 版本2.6.11 校驗的原理大體相似,靈活應(yīng)用??! 需求: 1根據(jù) 讀寫方式 去動態(tài)自動校驗規(guī)則; 2.只是監(jiān)聽掛載路徑,但因嵌套太多,表單監(jiān)聽的表單域不滿足自動監(jiān)聽的條件

    2024年02月05日
    瀏覽(30)
  • vue3 組合式 ant.design組件Table嵌套表格,從后端獲取數(shù)據(jù)并動態(tài)渲染

    在根據(jù)官方文檔使用ant.design中的嵌套表格時,發(fā)現(xiàn)官方文檔很多地方都不夠詳細。在過程中踩了不少坑,例如: 子表如何獲取父表的數(shù)據(jù)? 如何獲取子表的行索引? 如何讓子表的數(shù)據(jù)源來自父表該行的數(shù)據(jù)? 總之,最后還是磕磕絆絆做完了功能,于是第一時間把代碼整理

    2024年02月15日
    瀏覽(22)
  • SpringBoot + Ant Design Vue實現(xiàn)數(shù)據(jù)導(dǎo)出功能

    SpringBoot + Ant Design Vue實現(xiàn)數(shù)據(jù)導(dǎo)出功能

    以xlsx格式導(dǎo)出所選表格中的內(nèi)容 要求進行分級 設(shè)置表頭顏色。 首先我們需要添加一個用于到導(dǎo)出的按鈕上去,像這樣的: 至于它放哪里,是什么樣式可以根據(jù)自己的需求決定。 按鈕有了,下來我們開始實現(xiàn)這個按鈕的功能。 導(dǎo)出數(shù)據(jù)確定。 表格設(shè)置: 表頭添加以下代碼

    2024年02月10日
    瀏覽(28)
  • vue3 + Ant Design 實現(xiàn)雙表頭表格(橫向表頭+縱向表頭)

    vue3 + Ant Design 實現(xiàn)雙表頭表格(橫向表頭+縱向表頭)

    ?一、要實現(xiàn)的效果( 縱向固定表頭的表格,橫向表頭數(shù)量動態(tài)化 ) 二、這是后臺返回的數(shù)據(jù)格式(以企業(yè)為數(shù)組,每個企業(yè)里有個站點數(shù)組pointFactors) ? 三、代碼實現(xiàn)步驟 ? (1)定義縱向固定表頭 (2)動態(tài)生成橫向表頭( 從接口獲取數(shù)據(jù) ) ? (3)循環(huán)原始數(shù)據(jù),生

    2024年02月04日
    瀏覽(48)
  • Ant Design Vue實現(xiàn)表格雙擊編輯、添加新行、文字提示

    Ant Design Vue實現(xiàn)表格雙擊編輯、添加新行、文字提示

    早上剛上班,產(chǎn)品就朝我工位走了過來,一看大事不好,肯定又是來提需求的! 產(chǎn)品:做一個表格,要實現(xiàn)雙擊編輯的功能 我:做不了 產(chǎn)品:老板提的 我:好的,可以做 老板提的不能做也滴做?? 申明:項目基于Vue+Ant Design實現(xiàn) 想要實現(xiàn)雙擊編輯單元格,先開發(fā)一個簡單的

    2024年02月11日
    瀏覽(40)
  • ant-design-vue中upload上傳圖片、視頻實現(xiàn)預(yù)覽功能

    ant-design-vue中upload上傳圖片、視頻實現(xiàn)預(yù)覽功能

    有沒有小伙伴在使用ant-design-vue的upload組件時,發(fā)現(xiàn)api文檔在圖片預(yù)覽功能的介紹寥寥無幾,而且也沒提供視頻預(yù)覽的demo,在實際開發(fā)中碰到相應(yīng)的需求直撓頭~~~~,別急,下面來給大家分享一個我自己封裝的upload組件,符合需求可以直接在項目中放到組件目錄調(diào)用。 templat

    2024年02月12日
    瀏覽(24)
  • react ant-design實現(xiàn)導(dǎo)航菜單menu的路由設(shè)置/切換頁面

    react ant-design實現(xiàn)導(dǎo)航菜單menu的路由設(shè)置/切換頁面

    ant-design版本是5.1.1,路由版本是v6的 新版本的導(dǎo)航菜單路由設(shè)置與舊版的不太一樣,剛開始的時候甚至不知道該怎么寫 實現(xiàn)效果: 代碼: 首先,給導(dǎo)航菜單的menu添加點擊事件 修改item,通過設(shè)置點擊事件獲取點擊后的key值(key值即路由跳轉(zhuǎn)的頁面) 打印出來看看 獲取到的

    2024年02月12日
    瀏覽(22)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包