devexpress - 适用于 Blazor 的 DevExpress dxDataGrid -“当前电路存在未处理的异常”错误
问题描述
我正在为 Blazor 使用dxDataGrid来构建项目,但是当我尝试添加新行或编辑当前行时出现一些错误。
Error: There was an unhandled exception on the current circuit, so this circuit will be terminated. For more details turn on detailed exceptions in 'CircuitOptions.DetailedErrors'.
[2019-09-26T11:13:47.533Z] Information: Connection disconnected.
我的第一个想法是SignalR已断开连接。但我不知道为什么或如何配置?
有人有什么主意吗?你能告诉我吗?
根据 Mikhail 的建议,我得到了一些关于错误的新细节。第一次尝试时出现第一个错误,第二次尝试时出现第二个错误。
Error: System.NullReferenceException: Object reference not set to an instance of an object.
Uncaught (in promise) Error: Cannot send data if the connection is not in the 'Connected' State.
我的代码似乎有问题。但我仍然对错误没有任何想法,所以我将我的代码片段粘贴在下面。
<DxDataGrid Id="aa" Data="@activityDtos" @ref="@grid"
ShowFilterRow="false"
RowRemoving="@((dataItem) => OnRowRemoving(dataItem))"
RowUpdating="@((updatingDataItem, newValues) => OnRowUpdating(updatingDataItem, newValues))"
RowInserting="@((newValues) => OnRowInserting(newValues))">
<DxDataGridCommandColumn Width="150px" Context="编辑"></DxDataGridCommandColumn>
<DxDataGridColumn Field="@nameof(ActivityDto.ActivityCode)" Caption="Activity Code"></DxDataGridColumn>
<DxDataGridColumn Field="@nameof(ActivityDto.ActText1)" Caption="Text1"></DxDataGridColumn>
<DxDataGridColumn Field="@nameof(ActivityDto.ActText2)" Caption="Text2"></DxDataGridColumn>
<DxDataGridColumn Field="@nameof(ActivityDto.ActivityStatusID)" Caption="Status">
<DisplayTemplate>
@{
var feild = (context as ActivityDto).ActivityStatusID == "A" ? "Active" : "Inactive";
<label><span>@feild</span></label>
}
</DisplayTemplate>
<EditTemplate>
<DxComboBox Data="@(new List<string>() { "Active", "Inactive" })"
SelectedItem="@(((bool)((CellEditContext)context).CellValue) ? "Active" : "Inactive" )"
SelectedItemChanged="@(newCellValue => ((CellEditContext)context).OnChanged(newCellValue == "Active"))">
</DxComboBox>
</EditTemplate>
</DxDataGridColumn>
<DxDataGridColumn Caption="Default">
<DisplayTemplate>
@{
var id = Guid.NewGuid().ToString();
var isDefault = (context as ActivityDto).IsDefault;
<input id="@id" type="checkbox" checked="@isDefault" />
}
</DisplayTemplate>
</DxDataGridColumn>
</DxDataGrid>
还有C#的代码。
string ActivityCode, Text1Value, Text2Value, Status,Status1;
IQueryable<ActivityDto> activityDtos;
ActivityFormDataItem editFormData = new ActivityFormDataItem()
{
Status = "All",
CompanyId = 37
};
protected override async Task OnInitializedAsync()
{
activityDtos = await ActivitiesService.ActivitiesForAsync(editFormData);
SearchDtos = await ActivitiesService.SearchDtosForAsync();
}
async void OnRowRemoving(ActivityDto dataItem)
{
ActivitiesService.Remove(dataItem);
await InvokeAsync(StateHasChanged);
}
async void OnRowUpdating(ActivityDto dataItem, Dictionary<string, object> newValue)
{
ActivitiesService.Update(dataItem, newValue);
await InvokeAsync(StateHasChanged);
}
async void OnRowInserting(Dictionary<string, object> newValue)
{
ActivitiesService.Insert(newValue);
await InvokeAsync(StateHasChanged);
}
protected async Task OnAfterRenderAsync()
{
editFormData = new ActivityFormDataItem()
{
Status = Status1,
ActivityCode=ActivityCode,
CompanyId = 37,
Text1Value=Text1Value,
Text2Value=Text2Value
};
activityDtos = await ActivitiesService.ActivitiesForAsync(editFormData);
if (!string.IsNullOrEmpty(editFormData.Status))
editFormData.Status = editFormData.Status == "A" ? "Active" : "Inactive";
else
editFormData.Status = "All";
await InvokeAsync(StateHasChanged);
}
解决方案
请参阅官方https://github.com/DevExpress/Blazor存储库中有关当前电路文章和其他建议的未处理异常:
如果您看到此错误消息或类似消息,请将以下代码添加到 Startup.cs 文件中声明的 ConfigureServices 方法:
services.AddServerSideBlazor().AddCircuitOptions(options => { options.DetailedErrors = true; });
一旦您能够获得更多详细信息,请收集所有信息并向DevExpress 支持中心提交工单以获得专门的帮助。
推荐阅读
- php - PHP 中的 SQL 数据库创建错误(多个 SQL 连接)
- laravel-5 - 如何更改方法类 orm Laravel 中的密钥 ID?
- c - 如何优化 MAC 的搜索
- prolog - 结果未保存在序言变量上
- unity3d - 如何等待 PlayerPrefs.SetString 保存在磁盘上?
- javascript - 将浏览器窗口的一部分打印为 PDF 并发送到服务器以进行传真
- apache-kafka-streams - 为什么 RocksDB 库在 Kafka Streams 中抛出 loadlibrary 错误
- sqlite - SQLite 按日期求和整数
- python - python 3中电子邮件的条件正则表达式大小写匹配
- python - 无法将索引转换为日期格式