0

我遇到了一个小问题,我找不到解决方案。

当 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);       
    }
}
4

2 回答 2

1

您可以使用 aTemplateField来显示字段的Value属性(包含十进制值)Price。我在您的示例中添加了另一列

<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" />

    <asp:TemplateField HeaderText="Price/Unit Decimal">
        <ItemTemplate>
            <asp:Label ID="Label1" runat="server" Text='<%# Bind("Price.Value") %>'></asp:Label>
        </ItemTemplate>
     </asp:TemplateField>

  </Columns>
</asp:GridView>
于 2013-05-06T14:08:35.757 回答
0

我没有找到可行的解决方案。

我做了什么使它起作用:

我创建了一个新类,此时我使用了它。现在它起作用了:

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 ProductClass()
        {
            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();
于 2013-05-10T08:57:36.263 回答