Web应用程序开发中,大多数的电子商务网站都有网上购物这一功能模块,所以购物车程序的编写就显得非常重要。

  购物车的作用不外就是实现这些功能:添加物件、修改物件、删除物件、检查推车、查看推车等。在本文就讲解“添加物件”、“删除物件”和“查看推车”这三个功能。当然,这里只不过是一个简单的购物车类,完成的功能也不多,还不够完善,需要大家在这个基础做扩展使它的功能更加完善。

  C#是一种完全的OOP(Object Oriented Programming)语言,也是微软的主打语言,也可以说是未来的几个流行语言之一。本文的示例代码使用C#编写。以下是创建一个购物车类,它完成添加物件、删除物件和查看购物车物件这些功能,文件名ShoppingCart.cs:

using System;
using System.Web.UI;
using System.Collections; //使用Hashtable类必须引入该命名空间

namespace WendwCart //命名空间名称
{
 [Serializable]
 public class Stat_Class{ //定义商品类,保存商品的各种属性
  String ShangPinID; //商品ID
  String Sp_Name; //商品名称
  decimal Sp_Price; //商品价格
  int Sp_Quan; //商品数量
  public String ItemID{
   get{return ShangPinID;}
   set{ShangPinID=value;}
  }

  public String ShangpinName{
   get{return Sp_Name;}
   set{Sp_Name=value;}
  }

  public decimal Price{
   get{return Sp_Price;}
   set{Sp_Price=value;}
  }

  public int Quantity{
   get{return Sp_Quan;}
   set{Sp_Quan=value;}
  }

  public Stat_Class(String ItemID,String ShangpinName,decimal Price,int Quantity){ //构造方法,初始化商品的各个属性

   ShangPinID=ItemID;
   Sp_Name=ShangpinName;
   Sp_Price=Price;
   Sp_Quan=Quantity;
  }
 }

 [Serializable]
 public class ShoppingCart{
  Hashtable Cart_Orders=new Hashtable();
  public ICollection Orders{
   get{return Cart_Orders.Values;}
  }

  public decimal TotalCost{ //计算总价格
  get{
   decimal total=0;
   foreach(DictionaryEntry entry in Cart_Orders){
    Stat_Class order=(Stat_Class)entry.Value;
    total+=(order.Price*order.Quantity);
   }
   return total;
  }
 }

 public void AddItem(Stat_Class Order){ //添加物件方法
  Stat_Class order=( Stat_Class)Cart_Orders[Order.ItemID];
  if(order!=null)
   order.Quantity+=Order.Quantity;
  else
   Cart_Orders.Add(Order.ItemID,Order);
 }

 public void DeleteItem (String ItemID){ //删除物件
  if(Cart_Orders[ItemID]!=null)
   Cart_Orders.Remove(ItemID);
 }
}
}

  编译ShoppingCart.cs文件:

csc /t:library /out: ShoppingCart.dll ShoppingCart.cs

  部署ShoppingCart.dll组件到bin目录下。

  说明:

  为了保证不管使用什么样的会话模式都能够有效的保存会话状态,在定义类的前面加上了Serializable序列化。另外,为了使每个用户登录时都能创建一个类的实例,在Global.asax文件里加上:

<%@ Import Namespace="WendwCart" %>
<%@ Application Codebehind="Global.asax.cs" Inherits="HDLab.BBS.Global" %>
<script Language="C#" runat="server">

void Session_Start()
{
 Session["MyShoppingCart"]=new ShoppingCart();
}
</script>

  其中WendwCart是控件的命名空间名称。 在下一篇《购物推车程序开发——调用购物车类》中将讲解如何在ASP.NET页面中应用ShoppingCart.dll组件来添加、删除物件。


上一篇《购物推车程序开发——调用购物车类》文件定义和部署了一个购物车类(ShoppingCart.cs),其中AddItem()和DeleteItem()两个方法分别完成了商品的添加和删除功能。这一篇文章着重如何在ASPX文件里调用该购物车类,使用C#语言编写。

Default.aspx

<%@ Import Namespace="WendwCart"%>

<%@ Import Namespace="System.Data"%>

<%@ Import Namespace="System.Data.SqlClient"%>

 

 

 

<html>

 <body>

   <form runat="server">

     <table width="100%">

       <tr>

         <td><asp:Button Text="查看" OnClick=" View_ShoppingCart " runat="server"/></td>

       </tr>

     </table>

     <br>

     <center>

       <asp:DataGrid ID="MyDataGrid"

            AutoGenerateColumns="false" Cellpadding="2"

            BorderWidth="1" BorderColor="lightgray"

            Font-Name="Verdana" Font-Size="10pt"

            GridLines="vertical" Width="90%"

            OnItemCommand="OnItemCommand" runat="server">

        <columns>

        <asp:BoundColumn HeaderText="商品ID" DataField="ItemID"/>

        <asp:BoundColumn headerText="  " DataField=" ShangpinName "

             headerStyle-HorizontalAlign="center"/>

        <asp:BoundColumn HeaderText="  " DataField="Price"

             DataFormatString="{0:c}" headerStyle-HorizontalAlign="center"

             ItemStyle-HorizontalAlign="right"/>

        <asp:ButtonColumn HeaderText="  " Text="加入购物车"

             headerStyle-HorizontalAlign="center"

             ItemStyle-HorizontalAlign="center" CommandName="AddToCart"/>

        </columns>

       <HeaderStyle BackColor="teal" ForeColor="white" Font-Bold="true"/>

        <ItemStyle BackColor="white" ForeColor="darkblue"/>

        <AlternatingItemStyle BackColor="beige" ForeColor="darkblue"/>

        </asp:DataGrid>

        </center>    

   </form>

 </body>

</html>

//连接数据库绑定数据到DataGrid控件

<script Language="C#" runat="server">

 void Page_Load(Object sender,EventArgs e){

    if(!IsPostBack){

      String ConnectString=ConfigurationSettings.AppSettings["DataConnectionString"];

      SqlDataAdapter adapter=new SqlDataAdapter("select * from Tb_ShangPin where sp_Price!=0",ConnectString);

      DataSet ds=new DataSet();

      adapter.Fill(ds);

      MyDataGrid.DataSource=ds;

      MyDataGrid.DataBind();

    }

 }

//添加商品

 void OnItemCommand(Object sender,DataGridCommandEventArgs e){

      if(e.CommandName=="AddToCart"){

        Stat_Class order=new Stat_Class (e.Item.Cells[0].Text,e.Item.Cells[1].Text,Convert.ToDecimal(e.Item.Cells[2].Text.Substring(1)),1);

        ShoppingCart cart=(ShoppingCart)Session["MyShoppingCart"]; //创建实例

        if(cart!=null)

          cart.AddItem(order);

      }

 }

//查看购物车,通过Response.Redirect()转到View_ShoppingCart.aspx页面

 void View_ShoppingCart(Object sender,EventArgs e)

      {

        Response.Redirect("View_ShoppingCart.aspx");

      }

</script>

说明:本例使用到数据库,在运行程序之前,我们先创建一个数据库和表,分别取名为Test_DbTb_ShangPin。表Tb_ShangPin有很多字段,其中包含sp_idsp_Namesp_Price几个字段。接下来我们把连接数据库的字符串写进web.config文件里,代码如下:

<configuration>

 <appSettings>

     <add key="DataConnectionString" value="server=(local);database=Test_Db;Trusted_Connection=no;uid=sa;pwd=1234"/>

 </appSettings>

</configuration>

查看购物车程序View_ShoppingCart.aspx

<%@ Import Namespace="WendwCart"%>

<html>

 <body>

 <form runat="server">

    <table width="100%">

      <tr>

        <td>

          <asp:Button Text="继续购物" OnClick="Gonoshopping" runat="server"/>

         </td>

      </tr>

    </table>

    <br>

    <center>

      <asp:DataGrid ID="MyDataGrid"

           AutoGenerateColumns="false"

           Cellpadding="2"

           BorderWidth="1"

           BorderColor="lightgray"

           Font-Name="Verdana"

           Font-Size="10pt"

           GridLines="Vertical"

           Width="90%"

           OnItemCommand="OnItemCommand"

           runat="server">

        <columns>

        <asp:BoundColumn HeaderText="图书ID" DataField="ItemID"/>

        <asp:BoundColumn headerText="  " DataField=" ShangpinName "/>

        <asp:BoundColumn HeaderText="  " DataField="Price"

             DataFormatString="{0:c}" headerStyle-HorizontalAlign="center"

             ItemStyle-HorizontalAlign="right"/>

        <asp:BoundColumn HeaderText="数量" DataField="Quantity"

             headerStyle-HorizontalAlign="center"

             ItemStyle-HorizontalAlign="center"/> 

        <asp:ButtonColumn HeaderText="删除" Text="删除"

             headerStyle-HorizontalAlign="center"

             ItemStyle-HorizontalAlign="center" CommandName="DelFromCart"/>

       </columns>

        <HeaderStyle BackColor="teal" ForeColor="white" Font-Bold="true"/>

        <ItemStyle BackColor="white" ForeColor="darkblue"/>

        <AlternatingItemStyle BackColor="beige" ForeColor="darkblue"/>

        </asp:DataGrid>

    </center>

    <h3><asp:Label ID="Total" runat="server"/></h3>

    </form>

 </body>

</html>

 

 

 

<script Language="C#" runat="server">

 void Page_Load(Object sender,EventArgs e){

    ShoppingCart cart=(ShoppingCart)Session["MyShoppingCart"]; //创建实例

 

 

    if(cart !=null){

      MyDataGrid.DataSource=cart.Orders;

      MyDataGrid.DataBind();

      Total.Text=String.Format("合计:{0:c}",cart.TotalCost);

    }

 }

 void OnItemCommand(Object sender,DataGridCommandEventArgs e){

    if(e.CommandName=="DelFromCart"){

      ShoppingCart cart=(ShoppingCart)Session["MyShoppingCart"];

      if(cart != null){

         cart.DeleteItem(e.Item.Cells[0].Text);

         MyDataGrid.DataBind();

         Total.Text=String.Format("合计:{0:c}",cart.TotalCost);

      }

    }

 }

 public void Gonoshopping(Object sender,EventArgs e)

 {

    Response.Redirect("default.aspx");

 }

</script>

总结:这两篇文章只是简单的介绍一下购物推车的基本原理,要应用到实际项目中还需要做很多工作。
posted on 2006-07-27 09:55  zacard  阅读(887)  评论(0)    收藏  举报