簡體   English   中英

獲取網格行命令事件上的下拉列表選擇項

[英]Get the drop down list selected item on grid row command event

我有一個管理 Customer表和網格視圖customer

我正在嘗試更新網格記錄。 我想當我點擊編輯鏈接記錄顯示在表中。

我正在嘗試在Grid_Row_command 事件上執行此操作。

我在文本框中獲取記錄,但無法獲取選定的下拉記錄。

請告訴我如何做到這一點。

這是我的表格和 Gridview 的快照。

在此處輸入圖片說明

.

這是我的代碼-

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Mspl.Web.MobileTracking.BL;
using Mspl.MobileTracking.Model;

namespace Mspl.Web.MobileTracking.UserControls
{
    public partial class ManageCustomers : System.Web.UI.UserControl
    {
        Utility utility;
        string result = string.Empty;
        User user = new User();
        CustomerBL customerBL;
        Customer Customer = new Customer();
        CustomerBL Customers = new CustomerBL();
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                BindCountry();
                BindCustomer();
            }

            lblMessage.Text = string.Empty;
        }

        private void BindStates()
        {
            utility = new Utility();
            var states = utility.GetStates(ddlCountry.SelectedItem.Value);
            ddlState.DataSource = states;
            ddlState.DataTextField = "Name";
            ddlState.DataValueField = "ID";
            ddlState.DataBind();
            ddlState.Items.Insert(0, "--Select--");
        }

        private void BindCountry()
        {
            utility = new Utility();
            var countries = utility.GetCountries();
            ddlCountry.DataSource = countries.ToList<Country>();
            ddlCountry.DataTextField = "Name";
            ddlCountry.DataValueField = "ID";
            ddlCountry.DataBind();
            ddlCountry.Items.Insert(0, "--Select--");
        }

        private void BindDistricts()
        {
            utility = new Utility();
            var districts = utility.GetDistricts(ddlState.SelectedItem.Value);
            ddlDistrict.DataSource = districts;
            ddlDistrict.DataTextField = "Name";
            ddlDistrict.DataValueField = "ID";
            ddlDistrict.DataBind();
            ddlDistrict.Items.Insert(0, "--Select--");
        }

        private void BindCustomer()
        {
            gvCustomer.DataSource = Customers.GetAllCustomers();
            gvCustomer.DataBind(); 
        }


        protected void gvCustomer_RowCommand(object sender, GridViewCommandEventArgs e)
        {
            if (e.CommandName == "displayCustomer")
            {
                GridViewRow row = (GridViewRow)((Control)e.CommandSource).NamingContainer;
                hfCustomerId.Value = Convert.ToString(e.CommandArgument);
                Label lblCName = (Label)row.FindControl("lblCustomerName");
                txtCustomerName.Text = lblCName.Text;
                Label lblAdd1 = (Label)row.FindControl("lblAddressLine1");
                txtAddressline1.Text = lblAdd1.Text;
                Label lblAdd2 = (Label)row.FindControl("lblAddressLine2");
                txtAddressline2.Text = lblAdd2.Text;
                Label lblPhone = (Label)row.FindControl("lblPhone");
                txtPhone.Text = lblPhone.Text;
                Label lblMobile = (Label)row.FindControl("lblMobile");
                txtMobileNumber.Text = lblMobile.Text;
                Label lblCountry = (Label)row.FindControl("lblCountry");
                ddlCountry.SelectedIndex = Convert.ToInt32(lblCountry.Text);
                Label lblState = (Label)row.FindControl("lblState");
                ddlState.SelectedIndex = Convert.ToInt32(lblState.Text);
                Label lblDistrict = (Label)row.FindControl("lblDistrict");
                ddlDistrict.SelectedIndex = Convert.ToInt32(lblDistrict.Text);
                Label lblCity = (Label)row.FindControl("lblCity");
                txtCity.Text = lblCity.Text; 
            }
        }

        protected void ddlCountry_SelectedIndexChanged(object sender, EventArgs e)
        {
            BindStates();
        }

        protected void ddlState_SelectedIndexChanged(object sender, EventArgs e)
        {
            BindDistricts();
        }

        protected void btnUpdate_Click(object sender, EventArgs e)
        {
            Customer customers = new Customer();
            user = Session["UserDetails"] as User;
            customers.ID = hfCustomerId.Value;
            customers.Name = txtCustomerName.Text;
            customers.Mobile = txtMobileNumber.Text;
            customers.Phone = txtPhone.Text;
            customers.AddressLine1 = txtAddressline1.Text;
            customers.AddressLine2 = txtAddressline2.Text;
            customers.Country = ddlCountry.SelectedItem.Value;
            customers.State = ddlState.SelectedItem.Value;
            customers.District = ddlDistrict.SelectedItem.Value;
            customers.City = txtCity.Text;
            customers.UpdatedBy = user.ID;

            if (Page.IsValid)
            {
                var result = Customers.UpdateCustomer(customers);
                if (result == "Success")
                    lblMessage.Text = "Sucessfully Updated";
                else
                    lblMessage.Text = "Already Exists";

                BindCustomer();
                refreshControls();
            }

            setFormstatus(0);

        }
    }
}

我的網格代碼-

<asp:HiddenField ID="hfCustomerId" runat="server" />
                <asp:GridView ID="gvCustomer" runat="server" AutoGenerateColumns="False" CellPadding="4"
                    EnableModelValidation="True" ForeColor="#333333" GridLines="Both" 
                    onrowcommand="gvCustomer_RowCommand" onrowcreated="gvCustomer_RowCreated">
                    <AlternatingRowStyle BackColor="White" />
                    <EditRowStyle BackColor="#2461BF" />
                    <FooterStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />
                    <HeaderStyle HorizontalAlign="Left" CssClass="normalText" BackColor="#507CD1" Font-Bold="True"
                        ForeColor="White" />
                    <PagerStyle BackColor="#2461BF" ForeColor="White" HorizontalAlign="Center" />
                    <RowStyle BackColor="#EFF3FB" />
                    <SelectedRowStyle BackColor="#D1DDF1" Font-Bold="True" ForeColor="#333333" />
                    <Columns>
                        <asp:TemplateField HeaderText="Id">
                            <ItemTemplate>
                                <asp:Label ID="lblCustomerId" runat="server" Text='<%# Bind("ID") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField HeaderText="Name">
                            <ItemTemplate>
                                <asp:Label ID="lblCustomerName" runat="server" Text='<%# Bind("Name") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField HeaderText="AddressLine1">
                            <ItemTemplate>
                                <asp:Label ID="lblAddressLine1" runat="server" Text='<%# Bind("AddressLine1") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField HeaderText="AddressLine2">
                            <ItemTemplate>
                                <asp:Label ID="lblAddressLine2" runat="server" Text='<%# Bind("AddressLine2") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField HeaderText="Mobile">
                            <ItemTemplate>
                                <asp:Label ID="lblMobile" runat="server" Text='<%# Bind("Mobile") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                         <asp:TemplateField HeaderText="Phone">
                            <ItemTemplate>
                                <asp:Label ID="lblPhone" runat="server" Text='<%# Bind("Phone") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField HeaderText="Country">
                            <ItemTemplate>
                                <asp:Label ID="lblCountry" runat="server" Text='<%# Bind("Country") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField HeaderText="State">
                            <ItemTemplate>
                                <asp:Label ID="lblState" runat="server" Text='<%# Bind("State") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField HeaderText="District">
                            <ItemTemplate>
                                <asp:Label ID="lblDistrict" runat="server" Text='<%# Bind("District") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField HeaderText="City">
                            <ItemTemplate>
                                <asp:Label ID="lblCity" runat="server" Text='<%# Bind("City") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField>
                            <ItemTemplate>
                                <asp:LinkButton ID="linkName" runat="server" Text="Edit" CommandName="displayCustomer"  CommandArgument='<%# Eval("ID")%>' >
                                </asp:LinkButton>
                            </ItemTemplate>
                        </asp:TemplateField>
                    </Columns>
                </asp:GridView>

你找到了下拉菜單,先用你的狀態列表填充它,然后使用像

ddlState.Items.FindbyText(lblState.text).Selected=true;

你可以這樣試試

if (e.commandname == "displayCustomer") {
    GridViewRow gv = (GridViewRow)((Control)e.CommandSource).NamingContainer;
    label lblCountry = gv.findControl("lblCountry");
    label lblState = gv.findcontrol("lblState");
    label lblDistrict = gv.findcontrol("lblDistrict");


    //call function to fill your country


    ddlCountry.items.finbytext(lblCountry.text).selected = true;

    //call function to fill states based on ddlcountry selected item

    ddlState.items.finbytext(lblState.text).selected = true;


    //call function to fill district based on ddlStateselected item

    ddlDistrict.items.finbytext(lblDistrict.text).selected = true;



}

實際上,您不需要執行所有這些代碼。

Label lblCountry = (Label)row.FindControl("lblCountry");
ddlCountry.SelectedIndex = Convert.ToInt32(lblCountry.Text);
Label lblState = (Label)row.FindControl("lblState");
ddlState.SelectedIndex = Convert.ToInt32(lblState.Text);
Label lblDistrict = (Label)row.FindControl("lblDistrict");
ddlDistrict.SelectedIndex = Convert.ToInt32(lblDistrict.Text);

一種更好的方法是:

<asp:LinkButton ID="linkName" runat="server" Text="Edit" CommandName="displayCustomer"  CommandArgument='<%# Eval("ID")%>' ></asp:LinkButton>



public void gvCustomer_RowCommand(object sender, GridViewCommandEventArgs e)
    {
        // Here "i" is the id(CommandArgument='<%# Eval("ID")%>') of the record 
        //coming from the link button.
        int i = Convert.ToInt32(e.CommandArgument);

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

            // Execute your Database query with where condition for "i" 
            // and fetch the value in data reader. The Query will be like 
            // Select * from Table_Name where ID = i
            // This will get you the particular record for that ID only

            while (dr.Read())
            {
                DrpCountry.SelectedItem.Value = dr["CountryID"].ToString();
                DrpState.SelectedItem.Value = dr["StateID"].ToString();
                DrpDistrict.SelectedItem.Value = dr["DistrictID"].ToString();
            }
        }
    }

從下拉列表中選擇一個特定的值

ddlCountry.SelectedIndex=ddlCountry.Items.IndexOf(ddlCountry.Items.FindByText(lblCountry.Text));

更新:

問題是,當您選擇 Country DropDown的值時,它已被填充,而您的 State 和 City DropDown未填充,這就是它們不起作用的原因,

    protected void gvCustomer_RowCommand(object sender, GridViewCommandEventArgs e)
    {
        if (e.CommandName == "displayCustomer")
        {
            GridViewRow row = (GridViewRow)((Control)e.CommandSource).NamingContainer;
            hfCustomerId.Value = Convert.ToString(e.CommandArgument);
            Label lblCName = (Label)row.FindControl("lblCustomerName");
            txtCustomerName.Text = lblCName.Text;
            Label lblAdd1 = (Label)row.FindControl("lblAddressLine1");
            txtAddressline1.Text = lblAdd1.Text;
            Label lblAdd2 = (Label)row.FindControl("lblAddressLine2");
            txtAddressline2.Text = lblAdd2.Text;
            Label lblPhone = (Label)row.FindControl("lblPhone");
            txtPhone.Text = lblPhone.Text;
            Label lblMobile = (Label)row.FindControl("lblMobile");
            txtMobileNumber.Text = lblMobile.Text;
            Label lblCountry = (Label)row.FindControl("lblCountry");


            // -------------------------- changed code --------------------------

            ddlCountry.SelectedIndex = ddlCountry.Items.IndexOf(ddlCountry.Items.FindByText(lblCountry.Text))


            // at this point country should be filled and selected, so we can bind and select appropriate state
            BindStates();

            Label lblState = (Label)row.FindControl("lblState");
            ddlSate.SelectedIndex = ddlSate.Items.IndexOf(ddlSate.Items.FindByText(lblState.Text))

            // at this point states should be filled and selected, so we can bind and select appropriate District
            BindDistricts();


            Label lblDistrict = (Label)row.FindControl("lblDistrict");
            ddlDistrict.SelectedIndex = ddlDistrict.Items.IndexOf(ddlDistrict.Items.FindByText(lblDistrict.Text))

            //---------------------------------------------------------------------

            Label lblCity = (Label)row.FindControl("lblCity");
            txtCity.Text = lblCity.Text; 
        }
    }

正如您在評論中提到的, GridView中的Country列實際上是 Country Name NOT Country ID。 當您將此lblCountry.Text轉換為int32並嘗試設置索引時。 這應該給出我認為的錯誤。

您目前采用的方法似乎不正確,更好的方法可能是將網格中記錄的 ID 保存在某些HiddenField ,例如,在RowCommand ,從HiddenField選擇 ID,從數據庫中獲取數據,然后然后加載您的輸入框。

無論如何,作為一種解決方法,將CountryID與您的國家名稱一起保存在HiddenField

<asp:TemplateField HeaderText="Country">
    <ItemTemplate>
        <asp:Label ID="lblCountry" runat="server" Text='<%# Bind("Country") %>'></asp:Label>
        <asp:HiddenField ID="hfCountryID" runat="server" Value='<%# Bind("CountryID") %>'></asp:HiddenField>
    </ItemTemplate>
</asp:TemplateField>

然后你可以使用這個CountryID設置DropDown

var hfCountryID = row.FindControl("hfCountryID") as HiddenField;
ddlCountry.SelectedValue = Convert.ToInt32(hfCountryID.Text); 

另一種解決方法是使用國家/地區名稱查找項目並選擇它,

ddlCountry.SelectedIndex = ddlCountry.Items.IndexOf(ddlCountry.Items.FindByText(lblCountry.Text));

您所需要的只是創建一個函數來獲取國家或州的 ID 或任何您可以執行的操作:

ddlCounty.SelectedValue=CountyID.ToString();

嘗試這個,

ddlCountry.SelectedIndex = ddlCountry.Items.IndexOf
(ddlCountry.Items.FindByText(lblCountry.Text);

暫無
暫無

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

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