【问题标题】:Accessing text boxes and dropdown list of each row in asp.net GridView separately分别访问asp.net GridView中每一行的文本框和下拉列表
【发布时间】:2017-01-05 11:05:03
【问题描述】:

我有一个如下的网格视图

<asp:GridView ID="grid_flats_allflatslist" OnRowDeleting="grid_flats_allflatslist_RowDeleting" runat="server" Width="95%" CssClass="gridview" ShowFooter="true" AllowPaging="true" PageSize="8" BackColor="Black" BorderColor="#E7E7FF" BorderStyle="None" BorderWidth="1px" CellPadding="1" CellSpacing="1" frame="below" DataKeyNames="BlockID" AutoGenerateColumns="false">
    <Columns>
        <asp:BoundField DataField="BlockID" HeaderText="Block ID" Visible="false" />
        <asp:BoundField DataField="BlockName" HeaderText="Block Name" />
        <asp:TemplateField HeaderText="Flat Number">
            <ItemTemplate>
                <asp:TextBox ID="text_flats_listflatnumber" CssClass="textbox" onkeypress="return numeric(this);" MaxLength="5" runat="server"></asp:TextBox>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="Flat Number">
            <ItemTemplate>
                <asp:DropDownList ID="list_flats_listflattype" CssClass="droplist" runat="server" AutoPostBack="true" OnSelectedIndexChanged="list_flats_listflattype_SelectedIndexChanged">
                    <asp:ListItem Text="Bachelor" Value="Bachelor"></asp:ListItem>
                    <asp:ListItem Text="Family" Value="Family"></asp:ListItem>
                </asp:DropDownList>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="Max Vacancy">
            <ItemTemplate>
                <asp:TextBox ID="text_flats_listmaxvacancy" onkeypress="return numeric(this);" MaxLength="2" CssClass="textbox" runat="server"></asp:TextBox>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:CommandField ShowDeleteButton="true" DeleteText="Delete" />
    </Columns>
    <FooterStyle BackColor="#9e4900" ForeColor="#fff1e5" Font-Bold="false" Font-Underline="false" HorizontalAlign="Center" />
    <HeaderStyle BackColor="#9e4900" ForeColor="#fff1e5" HorizontalAlign="Center" />
    <PagerStyle BackColor="#ff8080" ForeColor="#660000" HorizontalAlign="Right" />
    <RowStyle BackColor="#ffe7d6" ForeColor="#660000" HorizontalAlign="Center" />
    <AlternatingRowStyle BackColor="#ffd6ba" ForeColor="#660000" HorizontalAlign="Center" />
    <SelectedRowStyle BackColor="#fff9f4" HorizontalAlign="Center" ForeColor="Black" />
</asp:GridView>

<asp:Button ID="button_flats_flatplus" CssClass="button" Height="30px" Width="25%" runat="server" Text="Add Flat" OnClick="button_flats_flatplus_Click" />

最初,这是空的,当我单击button_flats_flatsplus 按钮时,将在网格视图中添加一行,其中包含上述字段。它还将有 2 个文本框和一个下拉列表。按钮点击事件如下。

protected void button_flats_flatplus_Click(object sender, EventArgs e)
{
    DataTable dt;
    DataRow dr = null;
    if (ViewState["CurrentTable"] == null)
    {
        dt = new DataTable();
        dt.Columns.Add(new DataColumn("BlockID", typeof(string)));
        dt.Columns.Add(new DataColumn("BlockName", typeof(string)));
        dt.Columns.Add(new DataColumn("Column1", typeof(string)));
        dt.Columns.Add(new DataColumn("Column2", typeof(string)));
        dt.Columns.Add(new DataColumn("Column3", typeof(string)));
        dr = dt.NewRow();
        dr["BlockID"] = list_flats_blocklist.SelectedValue; // I get this value from a different list
        dr["BlockName"] = list_flats_blocklist.SelectedItem.Text; // I get this value from a different list
        dr["Column1"] = string.Empty;
        dr["Column2"] = string.Empty;
        dr["Column3"] = string.Empty;
        dt.Rows.Add(dr);
        ViewState["CurrentTable"] = dt;
        grid_flats_allflatslist.DataSource = dt;
        grid_flats_allflatslist.DataBind();
    }
    else
    {
        dt = (DataTable) ViewState["CurrentTable"];
        dr = dt.NewRow();
        dr["BlockID"] = list_flats_blocklist.SelectedValue; // I get this value from a different list
        dr["BlockName"] = list_flats_blocklist.SelectedItem.Text; // I get this value from a different list
        dr["Column1"] = string.Empty;
        dr["Column2"] = string.Empty;
        dr["Column3"] = string.Empty;
        dt.Rows.Add(dr);
        ViewState["CurrentTable"] = dt;
        grid_flats_allflatslist.DataSource = dt;
        grid_flats_allflatslist.DataBind();
    }
}

添加许多行后,网格视图将如下所示,

如果我在这里按删除,那么它会被成功删除。现在我将在文本框中输入值。但是当我从第 1 行中选择 Family 时,应该禁用第 1 行的 Max Vacancy 文本框,并将文本内容设为 --。如果我从第 1 行中选择 Bachelor,则应启用第 1 行中的 Max Vacancy 文本框并清除文本以输入值。对于我工作的任何行都应该这样做。但我不确定如何做到这一点,因为我在网格视图中只有一个文本框 ID,而且我不确定如何分别访问每一行元素。

输入所有值后,我将单击保存按钮,该按钮应将输入的所有值逐行插入到数据库中,就像在网格视图中一样。这也是我不知道该怎么做,因为我无法单独访问每一行文本框。有什么办法可以做到吗?

我的行删除代码如下,

protected void grid_flats_allflatslist_RowDeleting(object sender, GridViewDeleteEventArgs e)
{
    int index = Convert.ToInt32(e.RowIndex);
    DataTable dt = ViewState["CurrentTable"] as DataTable;
    dt.Rows[index].Delete();
    ViewState["CurrentTable"] = dt;
    grid_flats_allflatslist.DataSource = dt;
    grid_flats_allflatslist.DataBind();
}

将值插入数据库时​​,网格视图BlockID 的第一个绑定字段应该是主键。为了更好的可见性,我把它隐藏了。

【问题讨论】:

    标签: c# jquery mysql asp.net gridview


    【解决方案1】:

    试试这个来添加对 Flat Number 和 Max Vacancy 的验证

    $(document).on('change', '.droplist', function(){
         var parentRow=$(this).parents("tr:eq(0)");
         var text_flats_listmaxvacancy=$(parentRow).find('[id*="text_flats_listmaxvacancy"]');
    
         var _value=$(this).val();
         if(_value=="Family"){
             $(text_flats_listmaxvacancy).val("--");             
             $(text_flats_listmaxvacancy).attr("readonly",true);
         }
         else if(_value=="Bachelor"){
             $(text_flats_listmaxvacancy).val("");
             $(text_flats_listmaxvacancy).attr("readonly",false);
         }
    });
    
    //Code for save button to find each row and controls
    foreach(GridViewRow row in grid_flats_allflatslist.Rows)
    {
        TextBox text_flats_listflatnumber=(TextBox)row.FindControl("text_flats_listflatnumber"); 
        DropDownList list_flats_listflattype=(DropDownList)row.FindControl("list_flats_listflattype");
        TextBox text_flats_listmaxvacancy=(TextBox)row.FindControl("text_flats_listmaxvacancy");
    }
    

    从下拉列表中删除AutoPostBackOnSelectedIndexChanged,如下所示,

    <asp:DropDownList ID="list_flats_listflattype" CssClass="droplist" runat="server">
        <asp:ListItem Text="Bachelor" Value="Bachelor"></asp:ListItem
        <asp:ListItem Text="Family" Value="Family"></asp:ListItem>
    </asp:DropDownList>
    

    【讨论】:

    • 很好,当我点击家庭时,-- 的文字正在改变,当我选择单身汉时,它就很清楚了。但是启用和禁用没有发生
    • 我已经更新了代码并添加了只读属性。如果可行,请尝试此操作。
    • 没有还是不行,和之前一样启用/禁用不工作
    • 试试这个$('#text_flats_listmaxvacancy').attr('readonly', true);这个$(text_flats_listmaxvacancy).attr("readonly","readonly");的Insted
    • 好的,现在它正在工作:) 我从下拉列表中删除了AutoPostBackOnSelectedIndexChanged,现在它可以工作了。谢谢
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2013-09-02
    • 1970-01-01
    • 2017-03-25
    • 1970-01-01
    • 1970-01-01
    • 2014-01-12
    • 2021-09-18
    相关资源
    最近更新 更多