gpt4 book ai didi

c# - 分别访问asp.net GridView中每行的文本框和下拉列表

转载 作者:行者123 更新时间:2023-11-29 11:05:27 25 4
gpt4 key购买 nike

我有一个 GridView ,如下所示

<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 按钮时,将在 GridView 中添加一行,其中包含上述字段。它还将有 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();
}
}

添加许多行后, GridView 将如下所示,

My GridView

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

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

我的行删除代码如下,

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();
}

将值插入数据库时​​, GridView 的第一个绑定(bind)字段BlockID应该是主键。为了获得良好的可见性,我将其隐藏起来。

最佳答案

尝试添加对单位数量和最大空缺的验证

$(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>

关于c# - 分别访问asp.net GridView中每行的文本框和下拉列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41483375/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com