我正在使用 jquery 购物车http://plugins.jquery.com/project/smartcart2
任何人都可以帮助我实现 onAdded、onRemoved、onUpdated 方法,以便进行 Ajax 调用以在服务器端维护会话。每当添加/删除/更新对象并以 JSON 格式取回数据时,我都会在服务器上发出 Ajax 请求。我obj.attr("qty", eval(msg)[1]);
使用来自服务器的更新来更新数量。但是,如果我点击刷新或重新填充表数据,则购物车项目不再存在。因此,问题实际上是如何填充会话中的数据,以便产品在刷新等时仍保留在购物车中。
$('#SmartCart').smartCart({
onAdded: function(pObj,quantity){ cartAdded(pObj,quantity);},
onRemoved: function(pObj){ cartRemoved(pObj);},
onUpdated: function(pObj,quantity){ cartUpdated(pObj,quantity); },
});
function cartAdded(obj,qty){
var product_id = obj.attr("pid");
var quantity = qty;
// Ajax calls for adding product to cart
function(pObj,quantity){
cartAdded(pObj,quantity);}
}
function cartRemoved(obj){
var product_id = obj.attr("pid");
// Ajax call for removing product from cart
}
function cartUpdated(obj,qty){
var product_id = obj.attr("pid");
var quantity = qty;
// Ajax call for updating product on cart
}
function cartAdded(obj,qty){
var partNum = obj.attr("partNumber");
var quantity = qty;
$.ajax({
type: 'POST',
url: "json/sessionManager",
data : "partNum=" + partNum + "&qty=" + quantity,
dataType: "text/json",
success: function(msg){
obj.attr("qty", msg[1]);
},
error: function(httpRequest, textStatus, errorThrown) {
alert("status=" + textStatus + ",error=" + errorThrown);
}
});
}
我非常感谢您提出相同的建议。