2014-02-18 82 views
1

我正在嘗試將存儲在會話變量中的項目存入中繼器供用戶查看。但是,我不完全確定如何做到這一點(我是新會話變量)。基本上,當用戶輸入一次頁面上的項目數量時,它們將被帶到「訂單彙總」頁面,該頁面將顯示他們計劃購買的內容。我已經成功地設置了一個會話變量來包含用戶選擇的每個產品的sku和數量,但我不知道如何獲取信息。在中繼器內的會話變量內顯示項目?

我已將信息存儲在會話變量中,如[sku],[quantity]; [sku],[quantity]; [sku],[quantity]等等。我想我必須做一個拆分或基於逗號和分號的東西,但我不知道如何用會話變量來做到這一點。

包含要存儲在會話變量中的產品列表網頁代碼:

public partial class GojoptproductlistSublayout : System.Web.UI.UserControl 
{ 
    private void Page_Load(object sender, EventArgs e) 
    { 
     if(!Page.IsPostBack) 
     { 
      Item CurrentItem = Sitecore.Context.Item; 

      Item HomeItem = ScHelper.FindAncestor(CurrentItem, "gojoMarket"); 

      if (HomeItem != null) 
      { 
       Item ProductGroup = HomeItem.Axes.SelectSingleItem(@"child::*[@@templatename='gojoMarketOfficeBuildigProductMap']/*[@@templatename='gojoProductList']"); 

       if (ProductGroup != null) 
       { 
        Item[] LocationList = ProductGroup.Axes.SelectItems(@"child::*[@@templatename='gojoProductLocation' and @Active = '1']"); 
        if (LocationList != null) 
        { 
         DataSet ds = new DataSet(); 
         DataTable locations = ds.Tables.Add("locations"); 

         locations.Columns.Add("LocationName", Type.GetType("System.String")); 
         locations.Columns.Add("LocationID", Type.GetType("System.String")); 

         foreach (Item LocationItem in LocationList) 
         { 
          DataRow dr = locations.NewRow(); 
          dr["LocationName"] = LocationItem.Fields["Header"].Value; 
          dr["LocationID"] = LocationItem.ID.ToString(); 
          locations.Rows.Add(dr); 
         } 

         locationRepeater.DataSource = ds; 
         locationRepeater.DataMember = "locations"; 
         locationRepeater.DataBind(); 
        } 
       } 
      } 
     } 
    } 

    protected void SetInner(object sender, RepeaterItemEventArgs e) 
    { 
     if ((e.Item.ItemType != ListItemType.Footer) & (e.Item.ItemType != ListItemType.Header)) 
     { 
      Label refID = (Label)e.Item.FindControl("refID"); 
      Label test = (Label)e.Item.FindControl("test"); 
      Repeater areaRepeater = (Repeater)e.Item.FindControl("areaRepeater"); 

      Database db = Sitecore.Context.Database; 
      Item LocationAreaItem = db.Items[refID.Text]; 

      if (LocationAreaItem != null) 
      { 
       Item[] AreaList = LocationAreaItem.Axes.SelectItems(@"child::*[@@templatename='gojoProductLocationArea' and @Active = '1']"); 

       if (AreaList != null) 
       { 
        DataSet dset = new DataSet(); 
        DataTable areas = dset.Tables.Add("areas"); 

        areas.Columns.Add("AreaName", Type.GetType("System.String")); 
        areas.Columns.Add("Sku", Type.GetType("System.String")); 
        areas.Columns.Add("ProductName", Type.GetType("System.String")); 
        areas.Columns.Add("masterSku", Type.GetType("System.String")); 
        areas.Columns.Add("masterName", Type.GetType("System.String")); 
        areas.Columns.Add("Size", Type.GetType("System.String")); 
        areas.Columns.Add("SkuID", Type.GetType("System.String")); 
        areas.Columns.Add("AreaID",Type.GetType("System.String")); 
        areas.Columns.Add("productID", Type.GetType("System.String")); 

        foreach (Item AreaItem in AreaList) 
        { 
         DataRow drow = areas.NewRow(); 

         drow["AreaName"] = AreaItem.Fields["Header"].Value; 
         drow["AreaID"] = AreaItem.ID.ToString(); 

         areas.Rows.Add(drow); 

         Item[] SkuList = AreaItem.Axes.SelectItems(@"child::*[(@@templatename='gojoPTRefill' or @@templatename = 'gojoPTAccessories' or @@templatename = 'gojoPTDispenser' or @@templatename = 'gojoPTSelfDispensed') and @Active = '1']"); 

         foreach (Item ChildItem in SkuList) 
         { 
          Item MarketProduct = db.Items[ChildItem.Fields["Reference SKU"].Value]; 
          drow["productID"] = ChildItem.ID.ToString(); 

          if (MarketProduct != null) 
          { 
           Item MasterProduct = db.Items[MarketProduct.Fields["Master Product"].Value]; 
           if (MasterProduct != null) 
           { 
            DataRow newRow = areas.NewRow(); 

            if(MasterProduct.TemplateName == "gojoSKUSelfDispensed" || MasterProduct.TemplateName == "gojoSKURefill") 
            { 
             newRow["Size"] = MasterProduct.Fields["Size"].Value; 
            } 
            else 
            { 
             newRow["Size"] = "-"; 
            } 

            newRow["Sku"] = MasterProduct.Fields["SKU"].Value; 
            newRow["productID"] = MasterProduct.ID.ToString(); 

            Item MasterProductName = db.Items[MasterProduct.Fields["Complete Product Name"].Value]; 

            if (MasterProductName != null) 
            { 
             newRow["ProductName"] = MasterProductName.Fields["Complete Name"].Value; 

            } 
            areas.Rows.Add(newRow); 
           } 
          } 
         } 
        } 
        areaRepeater.DataSource = dset; 
        areaRepeater.DataMember = "areas"; 
        areaRepeater.DataBind(); 
       } 

      } 
     } 
    } 

    protected bool checkQtys(ref int ItemCnt, ref ArrayList LinesToOrder) 
    { 
     Repeater locationRepeater = (Repeater)FindControl("locationRepeater"); 

     bool validQtys = true; 
     string productID = ""; 
     int qty; 
     qtyErrorMsg.Text = ""; 
     qtyErrorMsgTop.Text = ""; 
     foreach (RepeaterItem repItem in locationRepeater.Items) 
     { 
      if (repItem != null) 
      { 
       Repeater areaRepeater = (Repeater)repItem.FindControl("areaRepeater"); 
       if (areaRepeater != null) 
       { 
        foreach (RepeaterItem skuItm in areaRepeater.Items) 
        { 

         if (skuItm != null) 
         { 
          Label SkuID = (Label)skuItm.FindControl("SkuID"); 
          Label qtyID = (Label)skuItm.FindControl("qtyID"); 

          PlaceHolder inner = (PlaceHolder)skuItm.FindControl("ProductTable"); 

           if (inner != null) 
           { 
            foreach (Control ct in inner.Controls) 
            { 
             if (ct is TextBox) 
             { 
              TextBox lineQty = (TextBox)ct; 
              Label prodID = (Label)inner.FindControl("productID"); 

              if (lineQty.Text != "") 
              { 
               try 
               { 
                int.Parse(lineQty.Text); 
                productID = prodID.Text; 
                qty = int.Parse(lineQty.Text); 

                if (qty > 0) 
                { 
                 noItemMsg.Visible = false; 
                 noItemMsgTop.Visible = false; 
                 ItemCnt++; //only count items with valid qty values 
                 LinesToOrder.Add(new LineItem(productID, qty)); 
                } 
                else 
                {//Qty is 0 or less error 
                 validQtys = false; 
                 qtyErrorMsg.Text = "Quantity must be a number<br />"; 
                 qtyErrorMsgTop.Text = "Quantity must be a number<br />"; 
                } 

               } 
               catch 
               {//NaN - display error msg 
                validQtys = false; 
                qtyErrorMsg.Text = "Quantity must be a number<br />"; 
                qtyErrorMsgTop.Text = "Quantity must be a number<br />"; 
               } 
              } 

             } 

            } 

           } 
         } 

        } 
       } 

      } 
     } 
     return validQtys; 
    } 

    class LineItem 
    {//This class will store the product information 
     public string SKUID; 
     public int Qty; 

     public LineItem(string InSKUID, int InQty) 
     { 
      this.SKUID = InSKUID; 
      this.Qty = InQty; 
     } 
    } 

    protected void orderSubmit(object sender, EventArgs e) 
    { 
     int ItemCnt = 0; 
     bool validQtys = true; 
     ArrayList LinesToOrder = new ArrayList(); 
     Label lb = FindControl("order") as Label; 

     if (checkQtys(ref ItemCnt,ref LinesToOrder)) 
     { 
      if (ItemCnt == 0) 
      {//make sure at least one item with proper qty amount is entered before submitting the order 
       validQtys = false; 
       noItemMsg.Visible = true; 
       noItemMsg.Text = "You must order at least one item<br />"; 
       noItemMsgTop.Visible = true; 
       noItemMsgTop.Text = "You must order at least one item<br />"; 
      } 
      if (validQtys) 
      {//save the information to a session variable and send users to order review page  
       try 
       { 
        foreach (LineItem WorkLine in LinesToOrder) 
        { 
         lb.Text += WorkLine.SKUID + ", " + WorkLine.Qty + ";"; 
        } 

        Session["orderComplete"] = lb.Text; 
       } 

       catch (Exception x) 
       { 
        Response.Write(x.Message.ToString()); 
       } 
       Response.Redirect("/united-states/market/office-buildings/obproductmap/OrderReview"); 

      } 
     } 
    } 
} 

這裏是,是爲了保持訂單彙總中繼設計師代碼:

<asp:Repeater ID="orderRepeater" runat="server" > 
    <headertemplate> 
     <tr> 
      <th>SKU</th> 
      <th>Quantity</th> 
     </tr> 
    </headertemplate> 
    <itemtemplate> 
     <tr> 
      <td><%#Eval("sku") %></td> 
      <td><%#Eval("qty") %></td> 
     </tr> 
    </itemtemplate> 
</asp:Repeater> 

這裏是後面的代碼:

private void Page_Load(object sender, EventArgs e) 
{ 
    Item CurrentItem = Sitecore.Context.Item; 
    Item HomeItem = ScHelper.FindAncestor(CurrentItem, "gojoMarket"); 

    if (Session["orderComplete"] != "") 
    { 
     if (HomeItem != null) 
     { 
      Item ProductGroup = HomeItem.Axes.SelectSingleItem(@"child::*[@@templatename='gojoMarketOfficeBuildigProductMap']/*[@@templatename='gojoOrderReview']"); 

      if (ProductGroup != null) 
      { 
       //this is where I am confused on how to proceed 


      } 

     } 
    } 
} 

一切正在工作,我對會話變量做了一個Response.Write測試,以確保它具有正確的信息,並且確實如此。

在此先感謝!

回答

2

在我試圖解決您的問題之前,讓我們看看一些基本知識。 Session可以容納一個對象,而不僅僅是一個字符串對象。我會改變:

if (Session["orderComplete"] != "") 

if (Session["orderComplete"] != null && Session["orderComplete"] != "") 

,如果你不這樣做,並且Session["orderComplete"]爲空,Session["orderComplete"] != ""將拋出一個錯誤object not set to an instance of an object

現在你的問題。將會話變量設置爲[sku],[quantity];[sku],[quantity];[sku],[quantity]不是一個好主意。首先,它不是面向對象的,2,它不會綁定到任何中繼器或數據源。您應該創建一個對象,這些對象的列表綁定到你的控制:

僞代碼:

class Program 
{ 
static void Main(string[] args) 
{ 
    List<Order> orders = new List<Order>(); 
    orders.Add(new Order { Sku = "ABC", Qty = 10}); 

} 
} 

public class Order { 

public String Sku { get; set; } 
public int Qty { get; set; } 

} 

然後,你可以綁定orders到您的中繼器。例如:

if (Session["orderComplete"] != null && Session["orderComplete"] != ""){ 
    List<Order> orders = Session["orderComplete"] as List<Order>; 
    myRepeater.DataSource = orders; 
    myRepeater.DataBind(); 
} 
+0

我喜歡這個想法。儘管最初我將信息存儲在一個ArrayList中,然後通過該信息進行排序以填充會話變量。我更新了我的帖子以顯示產品列表頁面的代碼.... –

+2

'if(Session [「orderComplete」]!= null && Session [「orderComplete」]!=「」)''可以修剪爲' if(!string.IsNullOrWhiteSpace(Session [「orderComplete」]))' –