二开案例.表单插件.通过内码获取单据数据包
【应用场景】
通过内码获取单据数据包。
【案例演示】
采购订单,通过内码获取单据数据包。
【实现步骤】
<1>编写表单插件,代码如下。
using Kingdee.BOS.App.Core;
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.ServiceHelper;
using Kingdee.BOS.Util;
using System.Collections.Generic;
using System.ComponentModel;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【表单插件】通过内码获取单据数据包
/// </summary>
[Description("【表单插件】通过内码获取单据数据包"), HotUpdate]
public class GetDataObjectByPKIDFormPlugIn : AbstractDynamicFormPlugIn
{
public override void BarItemClick(BarItemClickEventArgs e)
{
base.BarItemClick(e);
if (e.BarItemKey.EqualsIgnoreCase("test"))
{
var pkid = 100001;
// 方式1
// 全量数据包
var data1 = BusinessDataServiceHelper.LoadSingle(this.Context, pkid, this.View.BusinessInfo.GetDynamicObjectType());
// 指定字段数据包
var data2 = BusinessDataServiceHelper.LoadSingle(this.Context, pkid, this.View.BusinessInfo.GetSubBusinessInfo(new List<string>(new[] { "FBillNo", "FDate", "FPurchaseOrgId", "FDocumentStatus", "FMaterialId", "FQty" })).GetDynamicObjectType());
// 方式2
var data3 = BusinessDataServiceHelper.Load(this.Context, new object[] { pkid }, this.View.BusinessInfo.GetDynamicObjectType())[0];
// 指定字段数据包
var data4 = BusinessDataServiceHelper.Load(this.Context, new object[] { pkid }, this.View.BusinessInfo.GetSubBusinessInfo(new List<string>(new[] { "FBillNo", "FDate", "FPurchaseOrgId", "FDocumentStatus", "FMaterialId", "FQty" })).GetDynamicObjectType())[0];
}
}
}
}
<2>编写服务插件,代码如下。
using Kingdee.BOS.App.Core;
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.ServiceHelper;
using Kingdee.BOS.Util;
using System.Collections.Generic;
using System.ComponentModel;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【服务插件】通过内码获取单据数据包
/// </summary>
[Description("【服务插件】通过内码获取单据数据包"), HotUpdate]
public class GetDataObjectByPKIDServicePlugIn : AbstractOperationServicePlugIn
{
public override void EndOperationTransaction(EndOperationTransactionArgs e)
{
base.EndOperationTransaction(e);
var pkid = 100001;
// 方式1
// 全量数据包
var data1 = new ViewService().LoadSingle(this.Context, pkid, this.BusinessInfo.GetDynamicObjectType());
// 指定字段数据包
var data2 = new ViewService().LoadSingle(this.Context, pkid, this.BusinessInfo.GetSubBusinessInfo(new List<string>(new[] { "FBillNo", "FDate", "FPurchaseOrgId", "FDocumentStatus", "FMaterialId", "FQty" })).GetDynamicObjectType());
// 方式2
// 全量数据包
var data3 = new ViewService().Load(this.Context, new object[] { pkid }, this.BusinessInfo.GetDynamicObjectType())[0];
// 指定字段数据包
var data4 = new ViewService().Load(this.Context, new object[] { pkid }, this.BusinessInfo.GetSubBusinessInfo(new List<string>(new[] { "FBillNo", "FDate", "FPurchaseOrgId", "FDocumentStatus", "FMaterialId", "FQty" })).GetDynamicObjectType())[0];
}
}
}
<3>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<4>BOSIDE扩展采购订单,菜单集合新增菜单项,注册表单插件,操作列表选择审核操作注册服务插件,保存元数据,开发完毕。
【功能验证】
<1>VS附加IIS站点进程,启动调试,登录业务站点,打开采购订单新增界面,点击菜单【test】,断点命中后,即可观察数据包结构。
全量数据包:
部分数据包:
---------------------------------------------------------------------------------------------------------
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.表单插件.通过内码获取单据数据包
本文2024-09-23 04:08:11发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-163368.html