ASP.NET Core Blazor级联值和参数1基本用法

本文介绍了Blazor框架中如何使用CascadingValue组件从父组件向子组件,甚至是无限级别的后代组件传递参数。通过设置CascadingValue的Value属性,可以在父组件中改变值,然后在子组件中利用[CascadingParameter]特性接收并使用这些值。示例展示了在Index组件中点击按钮改变值,并在FetchData子组件中获取和使用该值的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 作用:

官方:将数据沿组件层次结构从祖先组件向下流向任意数量的后代组件

解释:Blazo里在父组件给子组件无限级别的传递参数的方法,方便子组件调用

  1. 用法:

1)使用CascadingValue组件提供级联值,并包裹需要级联的子组件。

其中,Value="..."为其属性值。

在Index.razor中:

@page "/"
<PageTitle>Index</PageTitle>
 
<button class="btn btn-primary" @onclick="onclick">Click me</button>
 
<CascadingValue Value="this">
    <FetchData></FetchData>
</CascadingValue>
 
@code{
    public string MyName{set;get;} = "Test";
 
    private void onclick()
    {
        MyName = "Test1";
    }
}

2)在子组件中,使用 [CascadingParameter] 特性来声明级联参数。

在FetchData中:

@code {
 
    [CascadingParameter]
    public Index index{set;get;}
 
    private WeatherForecast[]? forecasts;
 
    protected override async Task OnInitializedAsync()
    {
        forecasts = await ForecastService.GetForecastAsync(DateOnly.FromDateTime(DateTime.Now));
    }
}
  1. 结果:

可见,父组件的引用给传递下去了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值