插件中获取Entity不同类型字段时稍有区别,一般用如下两种方式:- Entity targetEntity = (Entity)context.InputParameters["Target"];
- 1.decamil val = Convert.ToDecimal(targetEntity["new_cmremainingamount"]);
- 2.decamil val = targetEntity.GetAttributeValue<decimal>("new_cmremainingamount");
复制代码 即通过强转或者GetAttributeValue方式,第一种方式不建议使用,赋值时用这种方式会比较简洁一些,但在获取值时,直接拿,如果值为空则会抛出空指针异常,用第二种方式,如果值为空则返回null,不为空就正常返回值。
附上CRM中字段类型:- 货币:new Money(Decimal)
- 查找:new EntityReference(objecttypename,Guid)
- 下拉:new OptionSet(Int)
- 选项集:false/true
- 时间:DateTime
- 整数:Integer
- 十进制数:Decimal
- 浮点数:Double
- 单行/多行文本:String
复制代码
但在实际插件代码中,去判断Moeny类型时,做一些直接的计算想一行代码设置值,就最好还是先判断一下entity中有没有这个字段,Entity实体通过查询返回或者插件的当前操作实体都是只返回有值的字段,没有值的字段不会再Entity中,所以使用以下方式:- if (!targetEntity.Contains("new_cmremainingamount")&& !targetEntity.Contains("new_partsremainingamount"))
- {
- return;
- }
复制代码 当然上面这种很常见,结合到一行代码中如下:- decimal singleVolume = 0;
- decimal singleWeight = 0;
- singleVolume = !detailEntity.Contains("new_singlevolume") ? 0 : detailEntity.GetAttributeValue<decimal>("new_singlevolume");
- singleWeight = !detailEntity.Contains("new_singleweight") ? 0 : detailEntity.GetAttributeValue<decimal>("new_singleweight");
- decimal amountBalance = 0;
- foreach (Entity en in entityCollection.Entities)
- {
- amountBalance += !en.Contains("new_cmremainingamount") ? 0 : en.GetAttributeValue<Money>("new_cmremainingamount").Value;
- }
- 或者也可以通过?.的方式
- amountBalance += en.GetAttributeValue<Money>("new_cmremainingamount")?.Value ?? 0;
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |