C# Blazor 学习笔记(2):组件模板化/插槽

文章目录

前言

组件模板化我们在WPF经常遇到,这里将一下Blazor是如何解决的。

组件模板

为什么要组件模板

虽然组件化了之后,我们写代码的速度已经很快了。但是组件模板会让我们写的更快。

这里有个需要。需要一个学生页面和老师页面。

不使用组件模板

学生

复制代码
<组件1/>
<组件2/>
<组件3/>
<组件4/>
....
<学生信息/>

老师

复制代码
<组件1/>
<组件2/>
<组件3/>
<组件4/>
....
<老师信息/>

使用后

声明组件

复制代码
<组件1/>
<组件2/>
<组件3/>
<组件4/>
....
<组件模板a/>

使用组件

复制代码
<组件模板>
	<组件模板a>
		<学生信息/>
	</组件模板a>
</组件模板>

<组件模板>
	<组件模板a>
		<老师信息/>
	</组件模板a>
</组件模板>

代码部分

Tips:我这里使用了元祖来作为临时变量。这个是C#的语法

java 复制代码
<h3>Model</h3>

<table>
    <thead>
        @HeadTemplate
    </thead>

    <tbody>
        @foreach(var item in Items)
        {
            <tr>@RowTemplate(item)</tr>
        }
    </tbody>
</table>

@code {

    //内容模板
    [Parameter]
    public RenderFragment HeadTemplate { get; set; }

    //数据模板,使用元祖来作为数据源
    [Parameter]
    public RenderFragment<(string Name,string Age)> RowTemplate { get; set; }
	//数据源
    [Parameter]
    public IReadOnlyList<(string Name,string Age)> Items { get; set; }

}

使用

java 复制代码
<Model Items="Lists">
    <HeadTemplate>
        <th>Name</th>
        <th>Age</th>
    </HeadTemplate>
    <RowTemplate>
        <!--@context是拿到数据模板的上下文,由于我们使用的是元祖,所以可以直接使用-->

        <td>@context.Name</td>
        <td>@context.Age</td>
    </RowTemplate>
</Model>


@code{
    public List<(string Name,string Age)> Lists{ get; set; }


    protected override Task OnInitializedAsync()
    {
        Lists = new List<(string Name, string Age)>
        {
            ("小王","11"),
            ("小刘","12"),
            ("小陈","13")
        };
        return base.OnInitializedAsync();
    }

}

和直接绑定数据有和区别?

对于组件更高的控制权,绑定数据源,如何展示是受模板组件限制的。使用了模板可以自定义展示效果。

相关推荐
在路上`37 分钟前
前端学习之后端java小白(四)之数据库设计
sql·学习
咔咔学姐kk3 小时前
大模型微调技术宝典:Transformer架构,从小白到专家
人工智能·深度学习·学习·算法·transformer
Jayyih3 小时前
嵌入式系统学习Day35(sqlite3数据库)
数据库·学习·sqlite
Hello.Reader4 小时前
从零到一上手 Protocol Buffers用 C# 打造可演进的通讯录
java·linux·c#
lingggggaaaa5 小时前
小迪安全v2023学习笔记(八十一讲)—— 框架安全&ThinkPHP&Laravel&Struts2&SpringBoot&CVE复现
笔记·学习·struts·安全·网络安全·laravel
浪扼飞舟5 小时前
c#基础(一)
开发语言·c#
CC数分5 小时前
零基础3个月上岸[特殊字符]自学数据分析路线
学习·数据挖掘·数据分析·大学生·考证
HAH-HAH5 小时前
【蓝桥杯 2024 国 Java A】粉刷匠小蓝
c++·学习·数学·算法·职场和发展·蓝桥杯·组合数学
酷讯网络_2408701606 小时前
多语言共享贩卖机投资理财共享售卖机投资理财系统
学习·开源
番薯大佬6 小时前
Python学习-day8 元组tuple
java·python·学习