VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > temp > C#教程 >
  • Session和Hashtable实现购物车

制作者:剑锋冷月 单位:无忧统计网,www.51stat.net
 

  本文示例源代码或素材下载

  本程序中以下测试环境中成功运行: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();  //显示商品总金额
}

 

  三、购物车截图

  a)、购物首页

Session+Hashtable实现购物车

  b)、购物车

Session+Hashtable实现购物车

 

 

  购物车的一些基本操作:

  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();  //显示商品总金额
}

 

  三、购物车截图

  a)、购物首页

Session+Hashtable实现购物车

  b)、购物车

Session+Hashtable实现购物车

 



相关教程