我在一个动态数据网站上工作,我遇到了墙。我有一个详细信息页面,可以看到每个员工的详细信息,然后我有一个单独的页面来编辑每个员工。我这样做是因为我需要在每个部门中为 Department 和 Job 使用 DropDownList 框。尽管如此,我在访问部门 ddl 时遇到问题,我认为这是因为它位于 EditItemTemplate 中。这是我所拥有的:
<asp:DetailsView ID="dvEmployee"
DataSourceID="EmpDVds"
AutoGenerateRows="false"
DataKeyNames="Id"
GridLines="None"
CellSpacing="10"
runat="server" DefaultMode="Edit">
<Fields>
<asp:TemplateField HeaderStyle-Font-Bold="true" HeaderText="Department: ">
<EditItemTemplate>
<asp:DropDownList ID="ddlDept" DataSourceID="DeptDDLds" DataTextField = "DepartmentName" DataValueField = "Id" runat="server" SelectedValue='<%#Bind("DeptID") %>' />
</EditItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderStyle-Font-Bold="true" HeaderText="Job Code: ">
<EditItemTemplate>
<asp:DropDownList ID="ddlJob" DataSourceID="JobDDLds" DataTextField = "JobName" DataValueField = "Id" runat="server" />
</EditItemTemplate>
</asp:TemplateField>
</Fields>
然后我尝试使用 ddlDept SelectedValue 来填充 ddlJob。这是我尝试使用的数据源。
<asp:SqlDataSource ID="JobDDLds"
SelectCommand="
SELECT
Id,
Code+' - '+[Desc] AS JobName,
Department_Id
FROM
JobCodes
WHERE
JobCodes.Department_Id = @DeptID"
ConnectionString="<%$ConnectionStrings:TrainingDatabaseConnection %>" runat="server" >
<SelectParameters>
<asp:ControlParameter ControlID="ddlDept" PropertyName="SelectedValue"
Name="DeptID" Type="Int32" />
</SelectParameters>
</asp:SqlDataSource>
我知道 Select 参数的格式是正确的,因为我正在使用另一个 ddl 来填充 DetailsView,并且我知道 Departments 和 JobCodes 之间的关系是正确的,因为我在 AddEmployee 页面中成功使用了它。
这是我得到的错误:
在 ControlParameter 'DeptID' 中找不到控件 'ddlDept'。
我假设它无法通过它的 ID 访问 ddlDept 是正确的,因为它位于 EditItemTemplate 中?我怎样才能解决这个问题?关于如何实现这一目标的其他建议?非常感谢任何和所有帮助。