DropDownList未更新到数据库
本文关键字:数据库 更新 DropDownList | 更新日期: 2023-09-27 18:24:14
我有三个正在填充的下拉列表,其中两个来自DB,另一个来自XML文件。问题是,我在提交方法中丢失了所选的值,我试图用这些下拉列表中的值更新数据库。以下是使用DB:的DDL之一的标记和代码
<div class="form-group">
<label class="col-lg-2 control-label" for="deptsDDL">Department *</label>
<div class="col-lg-6">
<asp:DropDownList ID="deptsDDL" class="form-control" placeholder="Department"
runat="server"></asp:DropDownList>
<asp:RequiredFieldValidator id="deptReqVal" runat="server"
ControlToValidate="deptsDDL" CssClass="text-danger"
InitialValue="Choose Department"
Display="Dynamic">* Select Department</asp:RequiredFieldValidator>
</div>
</div>
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
deptsDDL.Items.Add(new ListItem("Choose Department", "Choose Department"));
using (IDataReader deptReader = SiteDALC.GetDepartments())
{
while (deptReader.Read())
{
deptsDDL.Items.Add(new ListItem(deptReader.GetValue(0).ToString(),
deptReader.GetValue(0).ToString()));
}
var accountDept = SCWebUser.Current.ADProfile.Department;
if (deptsDDL.Items.FindByText(accountDept) != null)
deptsDDL.SelectedIndex =
deptsDDL.Items.IndexOf(deptsDDL.Items.FindByText(accountDept));
}
}
}
protected void RegisterBtn_Click(object sender, EventArgs e)
{
if (Page.IsValid)
{
SiteDALC.UpdateRegistration(
SCWebUser.Current.ADProfile.Username,
inputFirstName.Text.Trim(),
inputLastName.Text.Trim(),
"530" + phone1.Text.Trim() + phone2.Text.Trim(),
inputExtension.Text.Trim(),
faxNum,
cellNum,
titleDDL.SelectedValue,
addressDDL.SelectedValue,
city.Text.Trim(),
"CA",
zip.Text.Trim(),
deptsDDL.SelectedValue,
DateTime.Now);
}
}
我没有完全看到问题,但怀疑我没有掌握DataTextDield和DataValueField属性。
有人能提出解决方案吗?
原来我的Web.config文件中有以下内容:
<pages controlRenderingCompatibilityVersion="4.0" enableViewState="false">
...
</pages>
我不知道这是怎么发生的,但显然ViewState在站点级别被禁用了。