asp.net mvc通过cookie实现简单的购物车功能

asp.net mvc通过cookie实现简单的购物车功能,第1张

1.整个商品表,购物车

2.点击购买

没登陆情况下把商品Id(或是其他能标识唯一商品的值)存入Cookies 在购物车页面根据Cookies里存的id集合读取商品信息列出来 此时购物车页面读取的是cookies里商品id对应的信息

登录后把cookies里存的数据加到购物车表 点击购买直漏尘则接存入购物车表 此时购物车页面数据读取的是数返棚据库中商品数据

商品信息都有了 计算价格就简单兄岩了

这是比较简单的实现方式了

我的想法是将购买的东西用表保存,再将表保存到session[cart]中 ,点击购买前穗时会有一件商品信息,假设为保存到DataTable中的tab点击购买按钮的click事件:if(session[cart]==null) //如果是第一次购买{ DataTable table=new DataTable() //动态生成表 DataColumn column1=new DataColumn("GoodsName",typeof(string))//动态生成列 DataColumn column2=new DataColumn("GoodsPrice",typeof(double)) DataColumn column3=new DataColumn("GoodsNumber",typeof(int))//假设我的表中只显示商品名称,商品价格,商品数量颂首 table.Columns.add(column1) //将列添加到表中 table.Columns.add(column2)table.Columns.add(column3)DataRow row=table.newRow()row["GoodsName"]=tab.rows[0]["name"]//从tab表(只可能是一件商品)中拿到购买的商品名称列 row["GoodsPrice"]=tab.rows[0]["price"] //从tab表中拿到价格列row["GoodsNumber"]=1 //第一次购买默认数量就是1件 table.rows.add(row)//将row添加到表慧樱卜中 session["cart"]=table //将表放入到session中}else //第二次购买了{ DataTable shoppingCart=session["cart"] //从session中拿到table bool b=true for(DaraRow row in shoppingCart.Rows) { if(row["GoodsName"].toString()==tab[0]["name"].toString())//判断是否是同一件商品 { row["GoodsNumber"]=convert.toInt32(row["GoodsNumber"])+1 //将数量加上1 session["cart"]=shoppingCart //重新把表放入sessionb=false } } if(b) //没有相同的商品 { DataRow row=shoppingCart.newRow() row["GoodsName"]=tab[0]["Name"] row["GoodsPrice"]=tab[0]["price"] row["GoodsNumber"]=tab[0]["number"] shoppingCart.Rows.add(row)//添加新行 session["cart"]=shoppingCart //同样将表保存到session中 } response.redirect("cart.aspx") //跳到购物车界面去显示session中的表 }}没有验证,只是凭记忆敲的,如果有问题,我相信你自己也可以解决了;不过不知道符不符合你的要求。我习惯用Session保存表,也可以用集合。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/12406457.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存