在Gridview的BoundField中显示多个数据字段
本文关键字:数据 字段 显示 Gridview BoundField | 更新日期: 2023-09-27 18:22:02
我有一个绑定的asp:GridView
。在这里面,我有多个列,我试图从连接到一个字段中的两个数据库字段中获取数据。
如何做到这一点?
像这样的东西?
asp:BoundField DataField="field1 + ' ' + field2" HeaderText="Status" SortExpression="info"
非常确定您需要使用TemplateField而不是BoundField。
在您的GridView列块中:
<asp:TemplateField HeaderText="Name">
<ItemTemplate>
<%# Eval("FirstName") + " " + Eval("LastName")%>
</ItemTemplate>
</asp:TemplateField>
只是为了完整性,因为我搜索了一个解决方案,并在这里排名第一。。。
使用string.Format()
可以获得更大的灵活性
<asp:TemplateField HeaderText="Status">
<ItemTemplate>
<%# string.Format("{0} {1}", Eval("field1") ,Eval("field2"))%>
</ItemTemplate>
</asp:TemplateField>
在这里,您还可以使用string.Format()
的功能来格式化日期和数字类型,如下所述:https://learn.microsoft.com/en-us/dotnet/standard/base-types/formatting-types
样品:
<%# String.Format("{0:MM/dd/yyyy} - {1:N2}", Eval("dateValue1"), Eval("decimalValue2")) %>
另一种选择是用后面的代码在自定义方法中进行
ASPX:
<asp:TemplateField HeaderText="Status">
<ItemTemplate>
<asp:Label runat="server" Text='<%#GetStatus(Eval("Status1"),Eval("Status2")) %>'>
</asp:Label>
</ItemTemplate>
</asp:TemplateField>
编码背后:
public string GetStatus(object Status1, object Status2)
{
return (string)Status1 + " " + (string)Status2;
}
ToolTip='<%# Eval("LastName") & "-" & Eval("FirstName") %>'
这样试试。如果您使用两个数据集,则生成一个数据表并将其绑定到gridview。
<asp:BoundField DataField="<%# DataBinder.Eval(Container.DataItem, "f1")%>+ ' ' + <%# DataBinder.Eval(Container.DataItem, "f2")%>" HeaderText="Status" SortExpression="info"/>