微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Blazor为什么儿童剃须刀组件不起作用?

如何解决Blazor为什么儿童剃须刀组件不起作用?

我正在尝试将子组件包含到父组件中

但是子组件不起作用

下面是代码

==================== parent component razor ====================
<InfoDialog @ref="infoDialog"></InfoDialog>
==================== parent component code behind ====================
public InfoDialog infoDialog { get; set; }

public async Task AddToDB()
{
    infoDialog.Show("success","request complete!");
}
==================== child component razor ====================
<MatDialog @bind-IsOpen="@IsShow">
    <MatDialogTitle>@Title</MatDialogTitle>
    <MatDialogContent>
        <p>@Description</p>
    </MatDialogContent>
    <MatDialogActions>
        <MatButton OnClick="@Close">OK</MatButton>
    </MatDialogActions>
</MatDialog>
==================== child component code behind ====================
public partial class InfoDialog
{
    public bool IsShow { get; set; }
    public string Title { get; set; }
    public string Description { get; set; }

    public void Show(string _title,string _Description)
    {
        IsShow = true;
        Title = _title;
        Description = _Description;
    }
    public void Close()
    {
        IsShow = false;
    }
}

当我调用'AddToDB'函数时,我调用了子组件的show函数,但是未渲染子组件。谁能帮我吗?

对不起,我的英语不好

解决方法

尝试在子组件方法中调用StateHasChanged()

public void Show(string _title,string _Description)
{
    IsShow = true;
    Title = _title;
    Description = _Description;
    StateHasChanged();
}

public void Close()
{
    IsShow = false;
    StateHasChanged();
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。