string[,] strStk = new string[100,8];
if(System.Web.HttpContext.Current.Session["MyShopping"] != null)
{
strStk = (string[,])System.Web.HttpContext.Current.Session["MyShopping"];
for(int i=0;i<strStk.GetLength(0);i++)
{
if(strStk[i,0] == null)
{
strStk[i,0]=strSeqNo.ToString();
strStk[i,1]=strStkName.ToString();
strStk[i,2]=strSpec.ToString();
strStk[i,3]=strUnit.ToString();
strStk[i,4]=strTrnQty.ToString();
strStk[i,5]=strPrice.ToString();
strStk[i,6]=strSubTotal.ToString();
strStk[i,7]=strStkNo.ToString();
break;
}
}
}
问题补充:我写的一个购物车功能
我的理解 数组strStk 只是一个中间变量, 刚进来的时候把 Session["MyShopping"] 复给strStk ,然后给strStk追加数据,最后在把strStk复给Session["MyShopping"] ,这个时候Session["MyShopping"] 才是最新的数据
可是实际情况我并没有把strStk复给Session["MyShopping"] ,Session["MyShopping"] 就是最新数据了
if(System.Web.HttpContext.Current.Session["MyShopping"] != null)
{
strStk = (string[,])System.Web.HttpContext.Current.Session["MyShopping"];
for(int i=0;i<strStk.GetLength(0);i++)
{
if(strStk[i,0] == null)
{
strStk[i,0]=strSeqNo.ToString();
strStk[i,1]=strStkName.ToString();
strStk[i,2]=strSpec.ToString();
strStk[i,3]=strUnit.ToString();
strStk[i,4]=strTrnQty.ToString();
strStk[i,5]=strPrice.ToString();
strStk[i,6]=strSubTotal.ToString();
strStk[i,7]=strStkNo.ToString();
break;
}
}
}
问题补充:我写的一个购物车功能
我的理解 数组strStk 只是一个中间变量, 刚进来的时候把 Session["MyShopping"] 复给strStk ,然后给strStk追加数据,最后在把strStk复给Session["MyShopping"] ,这个时候Session["MyShopping"] 才是最新的数据
可是实际情况我并没有把strStk复给Session["MyShopping"] ,Session["MyShopping"] 就是最新数据了
解决方案 »
- 八百里加急,win7 socket 问题,在线等!
- c# 中圆弧的等分问题
- 麻烦各位推荐几本.Net方面的书籍和基本程序设计方面的书(国内的坚决不要)
- 问个DataTable 的使用
- vb Format(5, "00") 在c# 如何写
- ado.net如何读取Access中的长二进制数据?
- help.....求一个sql2000 静默安装的脚本(无人值守那种)
- 请教WPF后台动态生成的WrapPanel怎么绑定数据
- C#WebBrowser自动点击延迟
- 求下载地址 ICSharpCode.SharpZipLib.dll
- MemoryStream的问题
- 高分求教c#中为什么打印预览和实际打印效果有差别
public static void BuyStock(string strSeqNo,string strStkName,string strSpec,string strUnit,string strTrnQty,string strPrice,string strSubTotal,string strStkNo)
{
string[,] strStk = new string[100,8];
if(System.Web.HttpContext.Current.Session["MyShopping"] != null)
{
strStk = (string[,])System.Web.HttpContext.Current.Session["MyShopping"];
for(int i=0;i<strStk.GetLength(0);i++)
{
if(strStk[i,0] == null)
{
strStk[i,0]=strSeqNo.ToString();
strStk[i,1]=strStkName.ToString();
strStk[i,2]=strSpec.ToString();
strStk[i,3]=strUnit.ToString();
strStk[i,4]=strTrnQty.ToString();
strStk[i,5]=strPrice.ToString();
strStk[i,6]=strSubTotal.ToString();
strStk[i,7]=strStkNo.ToString();
break;
}
else
{
if(strSeqNo == strStk[i,0].ToString() )
{
strStk[i,4]=Convert.ToString(Convert.ToDecimal(strStk[i,4].ToString())+1);
strStk[i,6]=Convert.ToString(Convert.ToDecimal(strStk[i,4].ToString())*Convert.ToDecimal(strStk[i,5].ToString()));
break;
}
}
}
}
else
{
strStk[0,0]=strSeqNo.ToString();
strStk[0,1]=strStkName.ToString();
strStk[0,2]=strSpec.ToString();
strStk[0,3]=strUnit.ToString();
strStk[0,4]=strTrnQty.ToString();
strStk[0,5]=strPrice.ToString();
strStk[0,6]=strSubTotal.ToString();
strStk[0,7]=strStkNo.ToString();
System.Web.HttpContext.Current.Session["MyShopping"] = strStk;
}
}
#endregion 只是全部
http://www.cnblogs.com/jailu/archive/2006/09/22/511885.html
物品定一个类:
编号,名称,价格,数量,统计
让后将这个对象放在List集合中,集合放在Session,这样就没有那样麻烦了啊
首先存在购买的对象:Product id ,name ,price,count (编号唯一,名称,价格,数量)
页面加载:List<Product> list=Session["list"] as List<Product>; if(list==null) list=new List<Product>();Session["list"]=list;
上面是创建一个购物车,List集合是用于存放物品的,Session使用保存状态如果我买一个物品A,其本身存在ID先判读是否买过:List<Product> list=Session["list"] as List<Product>;
bool falg=false; //判断是否存在已经买过
foreach (Product p in list)
{
if(p.ID==AID) //说明已经买过
{
p.Count++; //再买一个
falg=true;
break;
}
}if(falg==true)
{
}
else
{
Product pA=new Product();
....属性
list.Add(pA);
}
上面就实现在了买东西下面就是保存状态了
Session["list"]=list;买任何东西都是这样,首先判断买过没有,没有买过在创建一个对象放入集合
当然我写的可能有问题,没有验证,但思想就是这样,如果放到键值对存储的集合里面更好
Session+Hashtable实现购物车 本文主要描述了如何使用Session、Hashtable实现购物车功能,其中使用Castle.ActiveRecord来完成跟数据库的交互工作。本程序中以下测试环境中成功运行:Vistual Studio 2005+Sql Server 2005+Castle 2.0主要内容:
1.Hashtable简介
2.购物车实现方式
3.购物车截图一、Hashtable简介
在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似key/value的键值对,其中key通常可用来快速查找,同时key是区分大小写;value用于存储对应于key的值。Hashtable中key/value键值对均为object类型,所以Hashtable可以支持任何类型的key/value键值对。 在哈希表中添加一个key/value键值对:HashtableObject.Add(key,value);
在哈希表中去除某个key/value键值对:HashtableObject.Remove(key);
从哈希表中移除所有元素: HashtableObject.Clear();
判断哈希表是否包含特定键key: HashtableObject.Contains(key); 二、购物车实现方式
首先先明确一下,购物车中需要保存哪些东西?我觉得只需保存商品ID和商品数量就可以了,为什么呢?因为商品信息是保存在数据库中的,所以只需保存了商品ID就可以从数据库中检索到商品的其它信息,如商品名、商品单价等。至于保存商品数量我想不需要解释了吧。 根据购物车中需要保存的内容再结合Hashtable的特点,所以选用Hashtable来保存购物车信息是比较不错的选择,其中key值为商品ID,value值为商品数量,两者都为int类型。 本购物车系统中,购物车页面为Vehicle.aspx,该页面用来处理购物车的基本操作和显示购物车,每次访问该页面时应传入两个参数:id和opt。其中id为要购买的商品ID,opt是对商品的操作,如增加、减少、删除等。当id和opt值都为0时为查看购物车。 购物车的一些基本操作:
a)、购买商品
需要注意的地方:当购买商品时应判断购物车是是否已有同类商品,若有则只需要商品原有数量上递增1即可,若无只需添加一条新的数量为1的商品信息;
b)、增加已购买商品数量
c)、减少已购买商品数量
需要注意的地方:当减少商品数量时,若商品数量为0则应删除此类商品;
d)、删除已购买商品 完成购物车的基本操之后就是显示购物车了,用以下步骤显示购物车:遍历Hashtable,每次遍历时获取商品ID和商品数量,从数据库中检索商品信息,并把必要的信息显示在页面上。下面帖一下Vehicle.aspx页面的主要代码:protected void Page_Load(object sender, EventArgs e)
{
//若id和opt值都为空则重定向
if (Request["id"] == null || Request["opt"] == null)
{
Response.Redirect("Default.aspx");
}
Hashtable myHT; //若Session中不包含对象,则新建一个
if (Session["Vehicle"] == null)
{
myHT = new Hashtable();
Session["Vehicle"] = myHT;
} //从Session中获取Hashtable对象
myHT = (Hashtable)Session["Vehicle"]; //获取商品ID
int intID = Convert.ToInt32(Request["id"]);
//获取操作类型
string strOpt = Request["opt"]; //传入参数id=0,opt=0用于查看购物车
if (intID != 0)
{
if (strOpt == "1") //添加
{
if (myHT.Contains(intID))
{
myHT[intID] = (int)myHT[intID] + 1;
}
else
{
myHT.Add(intID, 1);
}
}
else if (strOpt == "2") //减少
{
myHT[intID] = (int)myHT[intID] - 1; if ((int)myHT[intID] == 0)
{
myHT.Remove(intID);
}
}
else if (strOpt == "3") //删除
{
myHT.Remove(intID);
}
} ShowVehicle(myHT);
}//查示购物车详细信息
private void ShowVehicle(Hashtable myHT)
{
int intTempID; //用于保存临时商品ID
int intTempQuantity; //用于保存临时商品数量 int intItemCount = 0; //购物车中商品数总计
decimal decimalTotalMoney = 0; //购物车中商品总金额 //遍历Hashtable,显示购物车显示信息
foreach (DictionaryEntry entry in myHT)
{
intTempID = Convert.ToInt32(entry.Key.ToString()); //从哈希表中获取商品ID
intTempQuantity = Convert.ToInt32(entry.Value); //从哈希表中获取指定商品ID的数量 Model.Items myItems = Model.Items.GetItemsByID(intTempID); //根据商品ID获得商品对象
intItemCount += intTempQuantity;
decimalTotalMoney += intTempQuantity * myItems.ItemPrice; //把新的商品信息添加到Table中
TableRow tr = new TableRow(); //显示商品名
TableCell tc = new TableCell();
Label lbItemName = new Label(); ;
lbItemName.Text = myItems.ItemName;
tc.Controls.Add(lbItemName);
tc.HorizontalAlign = HorizontalAlign.Center;
tr.Cells.Add(tc); //显示商品单价
tc = new TableCell();
Label lbItemPrice = new Label();
lbItemPrice.Text = myItems.ItemPrice.ToString();
tc.Controls.Add(lbItemPrice);
tc.HorizontalAlign = HorizontalAlign.Center;
tr.Cells.Add(tc); //显示商品数量
tc = new TableCell();
ImageButton ibReduce = new ImageButton();
ibReduce.ImageUrl = "~/images/reduce.gif";
ibReduce.PostBackUrl = "Vehicle.aspx?id=" + intTempID + "&opt=2";
tc.Controls.Add(ibReduce);
Label lbItemQuantity = new Label();
lbItemQuantity.Text = intTempQuantity.ToString();
tc.Controls.Add(lbItemQuantity);
ImageButton ibAdd = new ImageButton();
ibAdd.ImageUrl = "~/images/add.gif";
ibAdd.PostBackUrl = "Vehicle.aspx?id=" + intTempID + "&opt=1";
tc.Controls.Add(ibAdd);
tc.HorizontalAlign = HorizontalAlign.Center;
tr.Cells.Add(tc); //显示删除操作按钮
tc = new TableCell();
HyperLink hlDelete = new HyperLink();
hlDelete.Text = "删除";
hlDelete.NavigateUrl = "Vehicle.aspx?id=" + intTempID + "&opt=3";
tc.HorizontalAlign = HorizontalAlign.Center;
tc.Controls.Add(hlDelete);
tr.Cells.Add(tc); tbVehicle.Rows.Add(tr); //tbVehicle为服务器Table控件,用于显示购物车信息
} lblItemCount.Text = intItemCount.ToString(); //显示商品总数
lblMoney.Text = decimalTotalMoney.ToString(); //显示商品总金额
}