二开案例.表单插件.获取多选辅助资料名称和编码
【应用场景】
<1>获取多选辅助资料名称和编码。
<2>通过添加冗余字段存储多选辅助资料的名称和编码,变通实现多选辅助资料的列表查询功能。
【案例演示】采购订单,新增多选辅助资料字段,新增文本字段存储多选辅助资料字段的多个辅助资料的名称和编码,并实现列表查询多选辅助资料数据的功能。
【实现步骤】
<1>编写表单插件,代码如下。
using Kingdee.BOS;
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Core.Metadata.FieldElement;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.BOS.Util;
using System;
using System.Collections.Generic;
using System.ComponentModel;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【表单插件】获取多选辅助资料名称和编码
/// </summary>
[Description("【表单插件】获取多选辅助资料名称和编码"), HotUpdate]
public class GetMulAssistantNameFormPlugIn : AbstractDynamicFormPlugIn
{
public override void DataChanged(DataChangedEventArgs e)
{
base.DataChanged(e);
if (e.Field.Key.Equals("F_Jac_MulAssistant", StringComparison.OrdinalIgnoreCase))
{
// 获取多选辅助资料数据包集合
var objs = this.Model.GetValue(e.Field.Key) as DynamicObjectCollection;
// 获取多选辅助资料的名称
var assistantName = GettMulAssistantName((MulAssistantField)e.Field, objs);
this.Model.SetValue("F_Jac_MulLangText", assistantName);
// 获取多选辅助资料的编码
var assistantNumber = GettMulAssistantNumber((MulAssistantField)e.Field, objs);
this.Model.SetValue("F_Jac_Text", assistantNumber);
}
}
/// <summary>
/// 获取多选辅助资料的名称(多个名称用分号分割)
/// </summary>
/// <param name="field"></param>
/// <param name="objs"></param>
/// <returns></returns>
private LocaleValue GettMulAssistantName(MulAssistantField field, DynamicObjectCollection objs)
{
var lv = new LocaleValue();
if (objs == null | objs.Count == 0)
{
return lv;
}
foreach (var obj in objs)
{
var assistant = obj[field.PropertyName] as DynamicObject;
if (assistant != null)
{
var name = (LocaleValue)assistant["FDataValue"];
lv.Merger(name, ";");
}
}
return lv;
}
/// <summary>
/// 获取多选辅助资料的编码(多个编码用分号分割)
/// </summary>
/// <param name="field"></param>
/// <param name="objs"></param>
/// <returns></returns>
private string GettMulAssistantNumber(MulAssistantField field, DynamicObjectCollection objs)
{
var lv = new LocaleValue();
if (objs == null | objs.Count == 0)
{
return string.Empty;
}
var list = new List<string>();
foreach (var obj in objs)
{
var assistant = obj[field.PropertyName] as DynamicObject;
if (assistant != null)
{
list.Add((string)assistant["FNumber"]);
}
}
return string.Join(";", list);
}
}
}
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,新增多选辅助资料资料,多语言文本字段,文本字段,注册表单插件,保存元数据,开发完毕。
现在可以登录业务站点,打开采购订单新增界面,录入多选辅助资料后,即可自动获取该多选辅助资料的名称和编码集合啦。
列表查询多选辅助资料:
【知识点】
<1>辅助资料类型,对应元数据是[BOS_ASSISTANTDATA_DETAIL],但是多选辅助资料字段对应的元数据是[BOS_ASSISTANTDATA_SELECT]。
<2>多选辅助资料在数据包中的数据结构如下图所示,获取多选辅助资料的某个字段的值可参考如下数据包结构进行取值。
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.表单插件.获取多选辅助资料名称和编码
本文2024-09-23 04:20:22发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-164672.html