私は Breeze.js は初めてで、アイデアは素晴らしかったと思いますが、ここで少し立ち往生しています。ブリーズコントローラーが保存しようとするたびに、jsonにデータが含まれているにもかかわらず、「シーケンスに一致する要素が含まれていません」というメッセージが表示されます。ノックアウトを使用してブートストラップモーダルにバインドしていますが、saveChanges がトリガーされてそのエラーがスローされるまで、すべてが機能しているようです。json は正しいようです (すべての変更が含まれています)。コードが必要な場合はお知らせください
前もって感謝します
追加されたコードを編集します:
コントローラー
[BreezeController]
public class BreezeEntityController : ApiController
{
readonly BreezeEntityRepo repository = new BreezeEntityRepo();
[HttpGet]
public IQueryable GetEtCustomers()
{
if (User.Identity.IsAuthenticated)
{
Int32 idUser = WebSecurity.GetUserId(User.Identity.Name);
Int32 idSstuser = Helpers.Extensions.GetSstCustomerId(User.Identity.Name);
return repository.Customers.Cast<EtCustomer>().Where(o => (o.IdMain.HasValue && o.IdMain == idSstuser) || o.IdUser == idUser).AsQueryable();
}
return null;
}
[HttpGet]
public string Metadata()
{
return repository.Metadata();
}
[HttpPost]
public SaveResult SaveChanges(JObject saveBundle)
{
return repository.SaveChanges(saveBundle);
}
}
保存しようとしているjson:
{
"entities": [{
"IdSstCustomer": 12520,
"IdAddressType": 40,
"IdTitle": 10,
"Lastname": "Lieferadresse",
"Firstname": "Dummy",
"Title": null,
"Name": "Maximilian Jan",
"Email": "test@test.at",
"NLstop": null,
"Phone": null,
"Company": null,
"UID": "",
"Address": "Teststr 1",
"Address2": null,
"City": "Wien",
"ZipCode": "1110",
"State": null,
"Country": "AT",
"CreateDate": "2013-02-25T12:06:00Z",
"CreateUser": 22,
"UpdateDate": null,
"UpdateUser": null,
"ApplicationId": null,
"UserId": null,
"IdMain": 10080,
"IdUser": null,
"entityAspect": {
"entityTypeName": "EtCustomer:#interfaceLibrary",
"defaultResourceName": "tbl_sst_Customer",
"entityState": "Modified",
"originalValuesMap": {
"Firstname": "Jan",
"Lastname": "Maximilian Lieferadresse",
"Address": "Wienerstraße 53a",
"ZipCode": "4020",
"City": "Linz",
"Email": "test@test-vertrieb.at"
},
"autoGeneratedKey": {
"propertyName": "IdSstCustomer",
"autoGeneratedKeyType": "Identity"
}
}
}],
"saveOptions": {}
}
また、私のエンティティ モデルは外部 dll 内にあります。これが理由でしょうか?
よろしくジャン
編集申し訳ありませんが、これが最後のコード部分です。これはリポジトリです。
public class BreezeEntityRepo
{
readonly EFContextProvider<FaEntities> _contextProvider =
new EFContextProvider<FaEntities>();
public IQueryable<EtCustomer> Customers
{
get
{
return _contextProvider.Context.tbl_sst_Customer;
}
}
public string Metadata()
{
return _contextProvider.Metadata();
}
public SaveResult SaveChanges(JObject saveBundle)
{
return _contextProvider.SaveChanges(saveBundle);
}
}
}
ビューモデルは
var vm = {
people: ko.observableArray([]),
hide: ko.observable(true),
save: saveChanges,
newEtCustomer: ko.observable(
{
Title: "",
Firstname: "",
Lastname: "",
Email: "",
Address: "",
City: "",
ZipCode: "",
Country: ""
}),
addEtCustomer: addNewEtCustomer,
editEtCustomer: editEtCustomer
};
そして保存が呼び出されます
function editEtCustomer(customer) {
vm.save();
}
データがサーバー側コントローラーに正しくコミットされていること
よろしくジャン
編集:
さて、スタックトレースは
bei System.Linq.Enumerable.First[TSource](IEnumerable`1 source, Func`2 predicate)
bei Breeze.WebApi.EFContextProvider`1.GetEntitySetName(Type entityType)
bei Breeze.WebApi.EFContextProvider`1.ProcessSaves(Dictionary`2 saveMap)
bei Breeze.WebApi.EFContextProvider`1.SaveChangesCore(SaveWorkState saveWorkState)
bei Breeze.WebApi.ContextProvider.OpenAndSave(SaveWorkState saveWorkState)
bei Breeze.WebApi.ContextProvider.SaveChanges(JObject saveBundle, TransactionSettings transactionSettings)
bei WatShop.Models.Entity.BreezeEntityRepo.SaveChanges(JObject saveBundle) in c:\Projekte\ProjekteWeb\WatShop\WatShop\Models\Entity\BreezeEntityRepo.cs:Zeile 33.
bei WatShop.Controllers.BreezeEntityController.SaveChanges(JObject saveBundle) in c:\Projekte\ProjekteWeb\WatShop\WatShop\Controllers\BreezeEntityController.cs:Zeile 44.
bei lambda_method(Closure , Object , Object[] )
bei System.Web.Http.Controllers.ReflectedHttpActionDescriptor.ActionExecutor.<>c__DisplayClass13.<GetExecutor>b__c(Object instance, Object[] methodParameters)
bei System.Web.Http.Controllers.ReflectedHttpActionDescriptor.ActionExecutor.Execute(Object instance, Object[] arguments)
bei System.Web.Http.Controllers.ReflectedHttpActionDescriptor.<>c__DisplayClass5.<ExecuteAsync>b__4()
bei System.Threading.Tasks.TaskHelpers.RunSynchronously[TResult](Func`1 func, CancellationToken cancellationToken)
お役に立てれば
よろしくジャン