我有一个 MatBlazor 表,它有一个数据源(项目)和与表中每一行关联的复选框。如果我使用@bind-Value,我没有任何问题,一切都按设计工作。但是我正在向一个按钮添加验证,该按钮取决于列表中的任何项目是否已“选中”以启用它。
所以,我转而使用 ValueChanged 属性,它是一个 EventCallback 并且没有运气用所选值更新 UI。
我试过调用 StateHasChanged() 甚至 InvokeAsync(),但 UI 没有更新。
<MatTable Items="@Projects" class="mat-elevation-z5 create-build-list" PageSize="50" ShowPaging="false" FilterByColumnName="ProjectName" Striped="true">
<MatTableHeader>
<th>Name</th>
<th>Key</th>
<th>Type</th>
<th>Include</th>
</MatTableHeader>
<MatTableRow>
<td>@context.ProjectName</td>
<td>@context.Key</td>
<td>@context.ProjectType</td>
<td><MatCheckbox Label="Add To Build" ValueChanged="@((bool val) => CheckBoxValue(val, context))" ValueExpression="@(() => context.IsChecked)"></MatCheckbox></td>
</MatTableRow>
</MatTable>
这是方法
void CheckBoxValue(bool e, MyProjectKey key)
{
foreach(var p in Projects)
{
if(p.Key == key.Key)
{
p.IsChecked = true;
}
};
//-- I'll do more stuff here.
}
当它调用该函数但不更新 UI 时,我是否缺少某些东西。