问题描述
我定义了一个名为 snackbarOptions 的 Action 委托,所以我可以在添加小吃店时使用它,而不是在 Snackbar.Add() 函数调用中声明它
Action<SnackbarOptions> snackbarOptions = (options) =>
{
options.RequireInteraction = true;
options.Action = "UKLONI DUPLIKAT";
options.ActionColor = Color.Error;
options.ActionVariant = Variant.Filled;
options.Onclick = async snackbar =>
{
await DeleteDependency(readStep,readDependency);
};
};
现在每当我想添加小吃店时,我只需传递 options 参数。 add 函数本身就是一个函数的参数。
duplicatesValidation.CheckForDuplicates((x,y,z) => Snackbar.Add("Message",MudBlazor.Severity.Warning,snackbarOptions));
这很好,但是,当我尝试将 snackbarOptions 作为函数参数传递时,我可以在 CheckForDuplicates() 中调用 Snackbar.Add > 函数我得到一个对象引用错误
duplicatesValidation.CheckForDuplicates(snackbarOptions);
编辑: 所以总结一下: 这有效:
public void CheckForDuplicates(Action<string,Severity,Action<SnackbarOptions>> SnackBaradd)
{
...
}
打电话 -
duplicatesValidation.CheckForDuplicates((x,snackbarOptions))
这不会:
public bool CheckForDuplicates(Action<SnackbarOptions> options)
{
...
}
打电话 -
duplicatesValidation.CheckForDuplicates(snackbarOptions)
编辑 2:
未处理的异常呈现组件:未将对象引用设置为对象的实例。 ... EditDependenciesDialog.razor.cs:line 188 该行代码:duplicatesValidation.CheckForDuplicates(duplicatesSnackbarOptions)
DuplicatesValidation.cs:line 35 该行代码:Snackbar.Add("x",Severity.Warning,options);
>
解决方法
考虑改用 local function 以避免丢失对象引用。
当您在运行时创建和存储委托时,您创建的委托可能在您调用它时未分配。
当使用本地方法时,它是预编译的,可以在其范围内的任何时间和任何地方引用。
Popen