簡體   English   中英

在Repeater Control里面的GridView里面的DropDownList不能正常工作

[英]DropDownList inside GridView inside Repeater Control not working properly

我正在使用Repeater控件在我的儀表板上生成表格。 在轉發器中,是一個顯示項目詳細信息的網格視圖。 在第一列中,gridview是一個下拉列表,用於選擇項目和該項目的選定索引,我正在獲取項目詳細信息,並且每個表格的計費過程仍在繼續。 現在問題是我只能在第一個轉發器中獲取項目詳細信息。 當我在另一個表或中繼器中選擇一個項目時沒有任何反應。 請幫我解決這個問題。

這是我的ASPX標記:

<div class="row">
                                <asp:Repeater ID="rptrTables" runat="server" OnItemDataBound="rptrTables_ItemDataBound">
                <ItemTemplate>
                <div class="col-md-6">
                  <div class="card card-info">
                   <div class="card-header with-border">
                     <h3 class="card-title"><asp:Label ID="lblTableNumber" runat="server" Text='<%# Eval("TableName") %>'></asp:Label></h3>
                     <div class="card-tools">
                       <button type="button" class="btn btn-tool" data-widget="collapse"><i class="fa fa-minus"></i></button>
                    </div>
                     </div>
                   <div class="card-body">
                   <div class="row">
                   <div class="col-md-12">
                  <div class="form-group">
                                                                <asp:GridView ID="grdOrder" runat="server" AutoGenerateColumns="false" AllowPaging="true" CssClass="table table-bordered table-hover table-responsive" GridLines="None" PageSize="10" OnRowDataBound="gvRowDataBound">
                                            <Columns>
                                                 <asp:CommandField ShowDeleteButton="true" ControlStyle-CssClass="btn btn-danger fa fa-trash" DeleteText="" HeaderText="Remove" />
                                                <asp:BoundField DataField="RowNumber" HeaderText="Sl. No." />
                                                <asp:TemplateField HeaderText="Item Name">
                                                    <ItemTemplate>
                                                        <asp:DropDownList ID="drpItemname" runat="server" CssClass="form-control select2" OnSelectedIndexChanged="GetItemDetails" AutoPostBack="true"></asp:DropDownList>
                                                    </ItemTemplate>
                                                </asp:TemplateField>
                                                <asp:TemplateField HeaderText="Price">
                                                    <ItemTemplate>
                                                        <asp:Label ID="lblUnitPrice" runat="server" Text='<%# Eval("UnitPrice")%>'></asp:Label>
                                                    </ItemTemplate>
                                                </asp:TemplateField>
                                                <asp:TemplateField HeaderText="Qty">
                                                    <ItemTemplate>
                                                        <asp:Label ID="lblQuantity" runat="server" Text='<%# Eval("Quantity")%>'></asp:Label>
                                                    </ItemTemplate>
          </asp:TemplateField>

             <asp:TemplateField HeaderText="Line Total">
                 <ItemTemplate>
                  <asp:Label ID="lblLineTotal" runat="server" Text="0"></asp:Label>
                  </ItemTemplate>
                  </asp:TemplateField>
                    <asp:TemplateField HeaderText="Add Item" ConvertEmptyStringToNull="False">
           <ItemTemplate>
            <asp:Button ID="ButtonAdd" runat="server" CssClass="btn btn-primary" Text="Add" OnClick="AddItem" CausesValidation="False" />
         </ItemTemplate>
          </asp:TemplateField>
            </Columns>
             </asp:GridView>
             </div>
             </div>
              </div>
              </div>
            <div class="card-footer">
             <div class="pull-right">
              <asp:Button ID="btnSubmit" runat="server" CausesValidation="false" TabIndex="2" CssClass="btn btn-primary" Text="Print KOT" />
                                <asp:Button ID="Button1" runat="server" CausesValidation="false" TabIndex="2" CssClass="btn btn-primary" Text="Print Final Bill" />
                                <asp:Button ID="Button2" runat="server" CausesValidation="false" TabIndex="2" CssClass="btn btn-primary" Text="Complete Order" />
                            </div>
                    </div>
                 </div>
               </div>
             </ItemTemplate>
              </asp:Repeater>
          </div>

我的c#代碼來獲取項目詳細信息:

protected void GetItemDetails(object sender, EventArgs e)
    {       
        foreach(RepeaterItem rptrItems in rptrTables.Items)
        {
            GridView gvItems = (GridView)rptrTables.Items[0].FindControl("grdOrder");
            foreach (GridViewRow row in gvItems.Rows)
            {
                DropDownList ddl = sender as DropDownList;
                Control ctrl = row.FindControl("drpItemName") as DropDownList;
                if (ctrl != null)
                {
                    DropDownList ddl1 = (DropDownList)ctrl;
                    if (ddl.ClientID == ddl1.ClientID)
                    {
                        Label UnitPrice = row.FindControl("lblUnitPrice") as Label;
                        Label QTTY = row.FindControl("lblQuantity") as Label;
                        Label UPrice = row.FindControl("lblUnitPrice") as Label;
                        Label LINETOTAL = row.FindControl("lblLineTotal") as Label;
                        SqlConnection conn = new SqlConnection(constring);
                        conn.Open();
                        if (ctrl != null)
                        {
                            if ((ddl1.ID == ddl.ID) && (ddl1.SelectedIndex == ddl.SelectedIndex))
                            {
                                string str = "select * from ItemMaster where ItemName='" + ddl1.SelectedItem.ToString() + "'";
                                SqlCommand com = new SqlCommand(str, conn);
                                SqlDataReader reader = com.ExecuteReader();
                                while (reader.Read())
                                {
                                    UnitPrice.Text = reader["UnitPrice"].ToString();
                                    QTTY.Text = reader["Quantity"].ToString(); ;
                                    decimal totamt = Convert.ToDecimal(QTTY.Text) * Convert.ToDecimal(UnitPrice.Text);
                                }
                                reader.Close();
                                conn.Close();
                            }
                            else
                            {
                                ScriptManager.RegisterStartupScript(this, this.GetType(), "swal", "swal('Item already selected, you can increase the quantity instead!', 'warning');", true);
                            }
                        }

                    }
                }
            }
        }             
    }

屏幕截圖1

畫面2

您的代碼中存在問題。 你總是從轉發器控件中選擇第一項,

GridView gvItems =(GridView)rptrTables.Items [0] .FindControl(“grdOrder”);

更改代碼以從foreach循環中獲取項目,因此您的代碼將是

GridView gvItems = (GridView)rptrItems.FindControl("grdOrder");

嘗試每次使用rptrItems而不是轉發器控件的第一項。

希望這會有所幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM