asp.net-mvc - Ext.net:如何设置组合框以更改外键字段并通过 AutoAsync() 保存?
问题描述
我对 GridPanel 有一些问题。表 Request 中的列 Brigade 是一个外键。如何显示组合框以更改此字段?此代码显示组合框,但值未设置为 GridPanel 中的字段。当我尝试更改某些字段时 AutoAsync() 得到一个异常 - 状态代码 500。
@model IEnumerable<GeoSystem.Models.Request>
@(Html.X().Store()
.ID("BrigadeStore")
.Model(Html.X().Model()
.Fields(
new ModelField("id", ModelFieldType.Int) { Mapping = "BrigadeID" },
new ModelField("name", ModelFieldType.String) { Mapping = "BrigadeName" }
)
)
.Proxy(Html.X().AjaxProxy()
.Url(Url.Action("GetBrigades"))
.Reader(Html.X().JsonReader().RootProperty("data"))
)
)
@(Html.X().GridPanel()
.ID("GridPanelRequest")
.Store(
Html.X().StoreForModel().ID("StoreRequest")
.AutoSync(true)
.ShowWarningOnFailure(false)
.SyncUrl(Url.Action("RequestHandleChanges"))
)
.Icon(Icon.Table)
.Frame(true)
.Title("Заявки")
.Height(430)
.Width(500)
.StyleSpec("margin-top: 10px;")
.ColumnModel(
Html.X().ColumnFor(Model, m => m.RequestName)
.ToBuilder<Column.Builder>()
.Flex(1)
.Editor(
Html.X().TextField().AllowBlank(false)
),
Html.X().ColumnFor(Model, m => m.Start)
.ToBuilder<Column.Builder>()
.Flex(1)
.Editor(
Html.X().TextField().AllowBlank(false)
),
Html.X().ColumnFor(Model, m => m.Brigade.BrigadeName)
.ToBuilder<Column.Builder>()
.Flex(1)
.Editor(
Html.X().ComboBox()
.QueryMode(DataLoadMode.Remote)
.TriggerAction(TriggerAction.All)
.StoreID("BrigadeStore")
.ValueField("id")
.DisplayField("name")
)
)
.Plugins(
Html.X().CellEditing()
)
)
解决方案
我以这种方式解决了问题ComboBox
。为组合框的商店添加了一个新类。控制器返回此对象的列表。
public class BrigadeComboBox
{
public string BrigadeName;
public Brigade Brigade;
}
然后Store
对于ComboBox
实现喜欢
@(Html.X().Store()
.ID("BrigadeStore")
.Model(Html.X().Model()
.Fields(
new ModelField("brigade", ModelFieldType.Object) { Mapping = "Brigade" },
new ModelField("BrigadeName", ModelFieldType.String) { Mapping = "BrigadeName" }
)
)
.Proxy(Html.X().AjaxProxy()
.Url(Url.Action("GetBrigades"))
.Reader(Html.X().JsonReader().RootProperty("data"))
)
)
在 GridPanel 的存储模型字段中添加
new ModelField()
{
Name = "Brigade",
Type = ModelFieldType.Object
}
ColumnFor 我用 Column 替换了它
Html.X().Column()
.Text("Бригада")
.DataIndex("Brigade")
而Editor
对于Column
inColumnModel
是
.Editor(Html.X().ComboBox()
.QueryMode(DataLoadMode.Remote)
.TriggerAction(TriggerAction.All)
.StoreID("BrigadeStore")
.ValueField("brigade")
.DisplayField("BrigadeName"))
我还添加.Renderer("brigadeRenderer")
了Column
var brigadeRenderer = function (value) {
if (!Ext.isEmpty(value)) {
return value.BrigadeName;
}
return value;
};
但这并没有解决 AsyncTask 的问题。
推荐阅读
- node.js - 如何使用 Jest 在nest.js 应用程序上测试标头请求
- angular - Angular Ag-grid(值获取器不导出单元格的渲染值)
- c# - 在 Visual Studio 项目中加载自动生成的类
- c# - Ubuntu 上的 Visual Studio Code C# 构建错误
- javascript - 使用 Cannon.js 在 Three.js 中使导入的字符实体化
- sql - 从字符串中提取键
- tensorflow - 如何在另一个神经网络中使用一个神经网络的层?
- python - 如何使用 SMTP 和 IMAP 回复邮件?
- saml - SAML ADFS 注销
- python - pandas get_dummies() 用于具有预定义列表的多列