Diskuze: AJAX + Session
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 7 zpráv z 7.
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Omlouvám se za špatně vložený kód. Upraveno pro lepší čtení:
Nejde mi při použití AJAX udržet obsah Session a vrátit požadované
hodnoty.
Na jedné stránce mám seznam položek a zároveň košík. Chtěl bych pomocí
AJAX přesouvat položky do košíku.
Zkusil jsem: Na pohledu mám u každé položky:
<button onclick="Add(id)">Přidej</button >
Tlačítko volá fci:
function Add(id) {
$.ajax({
type: 'POST',
data: { 'id': id },
dataType: 'json',
url: '@Url.Action("Buy", "Cart")',
success: function (cart) {
tady chci vypisovat obsah košíku, ale nedostanu sem položky a vypisuje to chybu
}
});
}
V kontroleru mám:
public ActionResult Buy(int id)
{
EshopProductModel productModel = new EshopProductModel();
List<EshopItem> cart = new List<EshopItem>();
if (Session["cart"] == null)
{
cart.Add(new EshopItem { Product = productModel.find(id), Quantity = 1 });
Session["cart"] = cart;
}
else
{
cart = (List<EshopItem>)Session["cart"];
int index = isExist(id);
if (index != -1)
{
cart[index].Quantity++;
}
else
{
cart.Add(new EshopItem { Product = productModel.find(id), Quantity = 1 });
}
Session["cart"] = cart;
}
return Json(cart, JsonRequestBehavior.AllowGet);
}
Po return v kontroleru to funguje dobře. Return vynuluje Session a vypisuje
chybu:
Při serializaci objektu typu
System.Data.Entity.DynamicProxies.Product_A937DDFEAE1517F1E89CADED98C4A9BC173F6C7DD0C32897D56FF1E3FC97DA11
byl nalezen kruhový odkaz.
Zkoušel jsem:
return Json("aaa", JsonRequestBehavior.AllowGet);
ten naplněnou Session nechává a chybu nevypisuje, "aaa" předá do succes a lze ho vypsat.
Jak se zbavit chyby a předat data z kontroleru do pohledu?
Předem díky.
Ahoj,
hoď sem i třídu EshopProductModel, resp. co vrátí
EshopProductModel.find(...), podle chyby to vypadá, že v tom co vrátí
EshopProductModel.find(...) je odkaz na cart a začne se to točit dokola v
serializaci.
public class EshopProductModel
{
public MenuDTBfirstEntities db = new MenuDTBfirstEntities();
public goods find(string id)
{
return this.products.Single(p => p.id.Equals(id));
}
}
Nový poznatek: na SQL serveru jsem měl nějaké relace mezi tabulkami. Odstranil jsem je a vše začalo fungovat. Tam kde jsem je potřeboval v kódu jsem to upravil a vše jede. Nicméně mi není jasný, jak se s tím vypořádat, kdybych ty relace chtěl zachovat.
Myslím si, že v modelu vidím jednu výkonnostní chybku a to sice this.product.Single … id předpokládám máš primární klíč a tudíž tam nemůžou být 2 stejné, použij tedy First - první nalezený namísto Single - jediný nalezený, Single prohledá celá data, First najde 1. shodu a končí.
A teď řešení zacyklení serializace, vlastnosti, které nepotřebuješ serializovat nebo nechceš serializovat označ atributem [ScriptIgnore] nebo [JsonIgnore], podle toho, co používáš k serializaci viz. např. toto
Ahoj,
obecně bych ti doporučil neodesílat na klienta celé entity z EF. Vytvoř si vždy nějakou třídu s minimem potřebných informací a tu odesílej zpět.
Zobrazeno 7 zpráv z 7.