我遇到了一个小问题,我找不到解决方案。
当 gridview 被绑定时,所有价格都将显示为Microsoft.Xrm.Sdk.Money
而不是它的值。
有谁知道为什么会发生这种情况以及如何改变它?
这是我的网格视图:
<asp:GridView ID="ProductList"
runat="server"
AutoGenerateColumns="false"
OnRowDataBound="ProductList_OnRowDataBound">
<Columns>
<asp:BoundField
HeaderText="Productno."
DataField="ProductNumber"/>
<asp:BoundField
HeaderText="Product"
DataField="Name" />
<asp:BoundField
HeaderText="Price/Unit"
DataField="Price" />
</Columns>
</asp:GridView>
我用下面的代码填充它
Products = (from ppl in priceCatalog.price_level_product_price_levels
join prod in ServiceContext.ProductSet.ToList()
on ppl.ProductId.Id equals prod.ProductId
select new Product()
{
ProductId = prod.ProductId,
ProductNumber = prod.ProductNumber,
Name = prod.Name,
Price = prod.Price,
//Price = ppl.Amount.Value,
PriceLevelId = ppl.PriceLevelId,
SubjectId = prod.SubjectId,
DefaultUoMId = ppl.UoMId
}).ToList();
var product = Products.Where(p => p.SubjectId.Id == filterTo).ToList();
ProductList.DataKeyNames = new[] { "ProductId" };
ProductList.DataSource = product.ToDataTable(XrmContext);
ProductList.DataBind();
目前它看起来像这样:
PNo. Name Price
1 Prod 1 Microsoft.Xrm.Sdk.Money
2 Prod 2 Microsoft.Xrm.Sdk.Money
3 Prod 3 Microsoft.Xrm.Sdk.Money
....
在 xrm.cs(为早期绑定 CRM 生成的文件)
以下是:
[Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("price")]
public System.Nullable<decimal> Price
{
get
{
return this.GetAttributeValue<System.Nullable<decimal>>("price");
}
set
{
this.SetAttributeValue<Microsoft.Xrm.Sdk.Money>("Price", "price", value);
}
}