字符串格式不适用于Eval
本文关键字:Eval 适用于 不适用 格式 字符串 | 更新日期: 2023-09-27 17:58:29
我在ASP中有以下货币格式的表达式。Net Gridview。它没有显示美元格式,尽管没有错误。这里缺少什么?
<%# String.Format("{0:C}", Convert.ToString(Eval("Amount")) ) %>
MARKUP
<asp:GridView ID="grdFinancialAmount" runat="server" AutoGenerateColumns="false">
<Columns>
<asp:TemplateField HeaderText="Emp ID">
<ItemTemplate>
<%# Eval("EmpID")%>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Amount">
<ItemTemplate>
<%# String.Format("{0:C}", Convert.ToString(Eval("Amount")) ) %>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
后面的代码
protected void Page_Load(object sender, EventArgs e)
{
Financial fin1 = new Financial { EmpID = 1, Amount = 5678 };
Financial fin2 = new Financial { EmpID = 2, Amount = -111111 };
List<Financial> accounts = new List<Financial>();
accounts.Add(fin1);
accounts.Add(fin2);
grdFinancialAmount.DataSource = accounts;
grdFinancialAmount.DataBind();
}
public class Financial
{
public int EmpID { get; set; }
public int Amount { get; set; }
}
为什么不两者都做。。。
<%# String.Format("{0:C}", Eval("Amount") ) %>
或
<%# ((int)Eval("Amount")).ToString("C") %>
在我看来,您试图将Amount转换为字符串两次,但无法将字符串格式化为货币。
Eval
接受字符串格式,不需要这些技巧。
简单如:<%# Eval("Amount", "{0:C}") %>
试试这个,对我有用。(.NET 4.5 C#,在网格视图中)
<%#Eval("Amout", "{0:C}").ToString()%>
试试这个:
<%# String.Format("{0:C}", int.Parse(DataBinder.Eval(Container.DataItem, "Amount").ToString())) %>