二开案例.表单插件.单选辅助资料
【应用场景】
在界面上显示并使用单选辅助资料列表字段。
单选辅助资料列表字段是一种特殊的基础资料字段,其数据源只能绑定自系统中已存在的辅助资料类型,其界面操作方式及插件控制方式和基础资料字段基本相同。
【案例演示】
采购订单,新增单选辅助资料列表字段,显示国家,编写表单插件,点击菜单后给单选辅助资料列表字段赋值。
【实现步骤】
<1>编写表单插件,代码如下。
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Core.Metadata.FieldElement;
using Kingdee.BOS.Core.SqlBuilder;
using Kingdee.BOS.ServiceHelper;
using Kingdee.BOS.Util;
using System;
using System.ComponentModel;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【表单插件】单选辅助资料
/// </summary>
[Description("【表单插件】单选辅助资料"), HotUpdate]
public class AssistantFieldFormPlugIn : AbstractDynamicFormPlugIn
{
public override void BarItemClick(BarItemClickEventArgs e)
{
base.BarItemClick(e);
var fieldKey = "F_Jac_Assistant_Country";
var assistantField = (AssistantField)this.View.BillBusinessInfo.GetField(fieldKey);
if (e.BarItemKey.Equals("tbSetValue1", StringComparison.OrdinalIgnoreCase))
{
// 方案1:用辅助资料内码赋值
// 设置国家为中国
var id = "46a524cf-5797-4e46-bd0a-7203fc426d9c";
var dynamicObj = BusinessDataServiceHelper.LoadSingle(this.Context, id, assistantField.RefFormDynamicObjectType);
this.Model.SetValue(fieldKey, dynamicObj);
this.View.ShowMessage("设置成功!");
return;
}
if (e.BarItemKey.Equals("tbSetValue2", StringComparison.OrdinalIgnoreCase))
{
// 方案2:用辅助资料编码赋值
// 设置国家为美国
var number = "America";
var queryBuilderParemeter = new QueryBuilderParemeter();
queryBuilderParemeter.FormId = "BOS_ASSISTANTDATA_SELECT";
queryBuilderParemeter.FilterClauseWihtKey = string.Format("FNumber ='{0}'", number);
var dynamicObjs = BusinessDataServiceHelper.LoadFromCache(this.Context, assistantField.RefFormDynamicObjectType, queryBuilderParemeter);
this.Model.SetValue(fieldKey, dynamicObjs[0]);
this.View.ShowMessage("设置成功!");
return;
}
}
}
}
/*
*
*
-- 辅助资料查询
SELECT a.FID AS 辅助资料类型内码,c.FNAME AS 辅助资料类型名称,a.FENTRYID AS 辅助资料内码,a.FNUMBER AS 辅助资料编码,b.FDATAVALUE AS 辅助资料名称,*
FROM T_BAS_ASSISTANTDATAENTRY a
LEFT JOIN T_BAS_ASSISTANTDATAENTRY_L b ON a.FENTRYID=b.FENTRYID AND b.FLOCALEID=2052
LEFT JOIN T_BAS_ASSISTANTDATA_L c ON a.FID=c.FID AND c.FLOCALEID=2052
WHERE a.FID='8a6e30f0-2c26-4639-aff5-76749daa355e'
*
*
*/
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,添加一个单选辅助资料列表字段,辅助资料类型设置为[国家],添加菜单子项,注册表单插件,保存元数据,开发完毕。
【功能验证】
现在可以登录业务站点,打开采购订单编辑界面,尝试使用一下单选辅助资料列表字段啦。
打开辅助资料列表给字段赋值:
插件通过辅助资料内码赋值:
插件通过辅助资料编码赋值:
---------------------------------------------------------------------------------------------------------
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.表单插件.单选辅助资料
本文2024-09-23 03:59:57发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-162449.html