Blazor:级联值和参数

2020年5月11日 6109点热度 0人点赞 0条评论
内容目录

级联值和参数


<CascadingValue Value="@_grandValue" Name="GrandValue">
    <Parent />
</CascadingValue>

当数据要从父子组件间流通时,我们有多种方法可以传递参数。但是如果层级超过两个的时候,就那么方便了。如果出现多个子组件的时候,就更加爆炸了。

级联值和参数提供了一种方便的方法,使祖先组件为其所有子代组件提供值,从而解决了上述问题。 级联值和参数还提供了一种协调组件的方法。

CascadingValue 组件用来包装组件层次结构。例如在祖先组件中调用下一层的组件:

<Parent /> 放进 <CascadingValue> 组件中,生成层次结构。


<CascadingValue Value="@_grandValue" Name="GrandValue">
    <Parent />
</CascadingValue>

而且底层组件需要使用属性来接收其祖先组件传递的参数,并且使用 [CascadingParameter] 特性修饰属性。

    [CascadingParameter(Name = "GrandValue")]
    string GrandValue { get; set; }

Name 不是必要的。

其使用示例如下:

创建三个 .razor 文件,Grand.razor 祖先组件,Parent.razor 父组件,Child.razor 子组件。

Child.razor 内容如下:


<div>
    孙组件:
    <p>传递的值: @ChildValue</p>
</div>
@code {
    [CascadingParameter(Name = "ChildValue")]
    string ChildValue { get; set; }
}

Parent.razor 内容如下:


父组件不做任何处理:
    <Child />

Grand.razor 内容如下:

@page "/g"
祖先组件:
<p>传递的值:<input @bind="_ChildValue" /></p>
提示:修改值后,鼠标点击其它地方即可更新孙组件的值
<!--Vaue:孙属性名称,Name:孙属性CascadingParameter特性的Name值-->
<CascadingValue Value="@_ChildValue" Name="ChildValue">
    <Parent />
</CascadingValue>
@code {
    private string _ChildValue = "666";
}

如果有多个值需要传递,就使用多个 CascadingValue,使用方法如下:

file

痴者工良

高级程序员劝退师

文章评论