如何foreach DataTable行并设置List变量
本文关键字:设置 List 变量 foreach DataTable 如何 | 更新日期: 2023-09-27 18:29:23
我有:
DataTable docTags;
List<IR_TagsName> tags = SomeClass.ShowTagsName(docIdentity);
foreach (DataRow dr in docTags.Rows)
{
foreach (IR_TagsName tag in tags)
{
if (dr["TagName"].ToString() == tag.TagName)
{
dr["TagValue"] = tag.RequestID;
}
}
}
TagsRepeater.DataSource = docTags;
TagsRepeater.DataBind();
中继器代码为:
<asp:Repeater ID="TagsRepeater" runat="server">
<ItemTemplate>
<div class="inputWrap">
<asp:Label ID="Label2" runat="server" AssociatedControlID="Tags"><%#DataBinder.Eval(Container.DataItem, "TagDescription")%>: </asp:Label>
<asp:HiddenField ID="TagName" runat="server" Value='<%#DataBinder.Eval(Container.DataItem, "TagName")%>' />
<asp:HiddenField ID="TagDataType" runat="server" Value='<%#DataBinder.Eval(Container.DataItem, "TagDataType")%>' />
<asp:TextBox ID="Tags" runat="server" Width="300" ReadOnly="true" Text='<%#DataBinder.Eval(Container.DataItem, "TagValue")%>' CssClass='<%# String.Format("Tag{0}", DataBinder.Eval(Container.DataItem, "TagName")) %>' />
<asp:Panel ID="ScriptPanel" runat="server" Visible='<%#(DataBinder.Eval(Container.DataItem, "tagdatatype").ToString() == "4" ? true : false)%>'>
<script type="text/jscript">
$(function () {
$(".Tag<%#DataBinder.Eval(Container.DataItem, "TagName")%>").datepicker({dateFormat: "dd.mm.yy"});
});
</script>
</asp:Panel>
</div>
</ItemTemplate>
</asp:Repeater>
这给了我一个例外:DataBinding: 'System.Data.DataRowView' does not contain a property with the name 'TagValue'.
我不确定这是否是循环DataRow和设置List变量的正确方法。。。如果需要,我会发布更多详细信息
DataBinding:"System.Data.DataRowView"不包含名为"TagValue"的属性
您的异常详细信息不言自明。在您的dr
中,您没有字段名称和TagValue
。当您尝试访问它时,会出现异常。
验证字段的名称并更改它。也许您想从数据库返回但忘记了,或者名称不同。