我有一个绑定到 sql 数据源的 gridview。
在 RowBound 方法中,我有这个代码来格式化可编辑的文本框:
protected void gridview_RowDataBound(Object sender, GridViewRowEventArgs e)
{
//Format the Edit row.
if (e.Row.RowIndex == gridview.EditIndex && e.Row.RowIndex >= 0)
{
//Add Ajax Calendar to Date fields
TextBox startDate= ((TextBox)e.Row.Cells[7].Controls[0]);
startDate.ID = "txtStartDate";
TextBox endDate= ((TextBox)e.Row.Cells[8].Controls[0]);
endDate.ID = "txtEndDate";
startDate.Attributes.Add("onchange", "javascript:GridviewAutoCalculateEndDate(this, " + endDate.ClientID + ");");
AjaxControlToolkit.CalendarExtender startDateCalendar = new AjaxControlToolkit.CalendarExtender();
startDateCalendar .ID = "startDateCalendar ";
startDateCalendar .TargetControlID = "txtStartDate";
startDateCalendar .Format = "dd/MM/yyyy";
AjaxControlToolkit.CalendarExtender endDateCalendar = new AjaxControlToolkit.CalendarExtender();
endDateCalendar.ID = "endDateCalendar";
endDateCalendar .TargetControlID = "txtEndDate";
endDateCalendar .Format = "dd/MM/yyyy";
e.Row.Cells[7].Controls.Add(startDate);
e.Row.Cells[8].Controls.Add(endDate);
e.Row.Cells[7].Controls.Add(startDateCalendar );
e.Row.Cells[8].Controls.Add(endDateCalendar );
}
}
上面只是将动态 AjaxCalendarExtender 添加到两个文本框和 javascript,获取在 startDate 文本框中输入的日期,添加一年并在 endDate 文本框中更新它(因此您不必手动更改它)。
我遇到的问题是,当我单击更新命令字段时,我得到对这两个文本框的空引用,并且其中的文本也被清除(与回发有关?)
这是更新代码:
protected void gridview_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
DateTime startDate= new DateTime();
DateTime.TryParseExact(e.NewValues[6].ToString(), "dd/MM/yyyy", CultureInfo.InvariantCulture, DateTimeStyles.AdjustToUniversal, out startDate);
DateTime endDate= new DateTime();
DateTime.TryParseExact(e.NewValues[7].ToString(), "dd/MM/yyyy", CultureInfo.InvariantCulture, DateTimeStyles.AdjustToUniversal, out endDate);
dataContext.UpdateDates(startDate, endDate);
PerformDataBind();
}
基本上 startDate 和 endDate 似乎在单击更新后立即清除并变为空。e.NewValues 似乎没有提取日期字段。如果我要删除动态数据,它们会更新得很好。
我错过了什么?