二开案例.表单插件.加载多类别基础资料引用数据包

【应用场景】
多类别基础资料字段的数据包是一个精简数据包,仅包含基础资料的内码、编码、名称等简单属性,有时候,需要基于多类别基础资料列表字段配置的引用属性,加载多类别基础资料引用数据包。
【案例演示】
采购订单,加载多类别基础资料引用数据包。

【实现步骤】
<1>编写表单插件,代码如下。
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Core.Metadata.EntityElement;
using Kingdee.BOS.Core.Metadata.FieldElement;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.BOS.ServiceFacade;
using Kingdee.BOS.ServiceHelper;
using Kingdee.BOS.Util;
using System.ComponentModel;
using System.Text;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【表单插件】加载多类别基础资料引用数据包
/// </summary>
[Description("【表单插件】加载多类别基础资料引用数据包"), HotUpdate]
public class GetDynamicObjectByItemClassFieldFormPlugIn : AbstractDynamicFormPlugIn
{
/// <summary>
/// 多类别基础资料字段标识
/// </summary>
const string FieldKey = "F_Jac_Item";
public override void BarItemClick(BarItemClickEventArgs e)
{
base.BarItemClick(e);
// TODO
if (e.BarItemKey == "test")
{
// 多类别基础资料字段
var itemClassField = (ItemClassField)this.View.BillBusinessInfo.GetField(FieldKey);
// 多类别基础资料列表字段
var itemClassType = (ItemClassTypeField)itemClassField.ControlField;
//检索行,单据头:0; 单据体从0开始;
var activeRow = this.View.Model.DataObject;
var rowIndex = 0;
if (itemClassField.Entity is EntryEntity)
{
this.View.Model.TryGetEntryCurrentRow(FieldKey, out activeRow, out rowIndex);
}
//获取 运行时实际指向的基础资料数据包
var itemClassDynamicObject = (DynamicObject)itemClassField.GetFieldValue(activeRow);
if (itemClassDynamicObject == null)
{
return;
}
var itemClassTypeValue = (string)this.View.Model.GetValue(itemClassType, rowIndex);
if (itemClassTypeValue == null)
{
return;
}
var itemClassTypeName = itemClassType.GetRefBaseData(itemClassTypeValue).Caption;
// 获取运行时实际指向的基础资料的LookUpObject对象
var lookupObject = itemClassF二开案例.表单插件.加载多类别基础资料引用数据包
【应用场景】多类别基础资料字段的数据包是一个精简数据包,仅包含基础资料的内码、编码、名称等简单属性,有时候,需要基于多类别基础资料...
点击下载文档文档为doc格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



