我正在使用带有 ASP.NET MVC、Entity Framework 和 OData 的 Kendo UI Grid。我在网格内也有记录 ID - 到目前为止一切都很好。
但是当我单击工具栏中的“添加新记录”时,ID 列在我编辑数据时显示为 0。
在我单击“更新”按钮后,它不会更改为正确的 ID(已由服务返回):
{
"odata.metadata":"http://localhost:61534/api/$metadata#AssetList/@Element",
"ID":17,
"ManufacturerName":"TEST",
"Name":"TEST",
"SerialNumber":"TEST",
"AssetStateID":1,
"AssetStateName":"TEST",
"NextCalibration":"2013-07-11T09:08:28.298Z"
}
当我刷新页面/浏览器时,会显示正确的 ID。
这是我的发布方法:
public override HttpResponseMessage Post(AssetListViewModel item)
{
// #### MG: CREATE ASSET
RSAMS.WebUI.Models.Asset asset = new Asset();
asset.Manufacturer = item.ManufacturerName;
asset.Name = item.Name;
asset.SerialNumber = item.SerialNumber;
asset.AssetStateID = 1; // IN USE
asset.NextCalibration = item.NextCalibration;
db.Asset.Add(asset);
db.SaveChanges();
// #### MG: RESPONSE
item.ID = asset.ID;
item.AssetStateID = asset.AssetStateID;
var response = Request.CreateResponse<AssetListViewModel>(HttpStatusCode.Created, item);
response.Headers.Location = new Uri(Url.Link("OData", new { id = item.ID }));
return response;
}
这是数据源js(它的一部分):
dataSource: {
type: "odata",
pageSize: 25,
serverSorting: true,
serverPaging: true,
transport: {
create: {
url: "/api/AssetList",
dataType: "json"
},
read: {
url: "/api/AssetList",
dataType: "json"
},
update: {
url: "/api/AssetList",
dataType: "json"
},
destroy: {
url: function (data) {
return "/api/AssetList([RW-PARAM])".replace("[RW-PARAM]", data.ID);
},
dataType: "json"
}