二开案例.表单插件.下拉列表使用自定义数据源(SQL)
【应用场景】使用自定义数据源,给下拉列表控件绑定下拉选项。
【案例演示】采购订单,新增下拉列表字段,绑定下拉项为币别。
【实现步骤】
<1>编写表单插件,代码如下。
using Kingdee.BOS;
using Kingdee.BOS.App.Data;
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.ControlModel;
using Kingdee.BOS.Core.Metadata;
using Kingdee.BOS.Util;
using System;
using System.Collections.Generic;
using System.ComponentModel;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【表单插件】下拉列表使用自定义数据源(SQL)
/// </summary>
[Description("【表单插件】下拉列表使用自定义数据源(SQL)"), HotUpdate]
public class FillComboFieldBySqlFormPlugIn : AbstractDynamicFormPlugIn
{
public override void AfterBindData(EventArgs e)
{
base.AfterBindData(e);
BindComboField();
}
private void BindComboField()
{
var enumList = GetEnumItems(this.Context);
var comboList = this.View.GetFieldEditor<ComboFieldEditor>("F_Jac_Combo", 0);
if (comboList != null)
{
comboList.SetComboItems(enumList);
}
}
/// <summary>
/// 从数据库读取自定义数据源并转换成枚举项集合
/// </summary>
/// <param name="ctx"></param>
/// <returns></returns>
private List<EnumItem> GetEnumItems(Context ctx)
{
// 获取币别数据
var enumList = new List<EnumItem>();
var sql = @"SELECT a.FCURRENCYID AS Id,b.FNAME AS Caption,a.FNUMBER AS Value FROM T_BD_CURRENCY a
LEFT JOIN T_BD_CURRENCY_L b ON a.FCURRENCYID=b.FCURRENCYID AND b.FLOCALEID=2052
WHERE a.FDOCUMENTSTATUS='C'";
var objs = DBUtils.ExecuteDynamicObject(ctx, sql);
if (objs != null && objs.Count > 0)
{
foreach (var obj in objs)
{
var enumItem = new EnumItem();
enumItem.Caption = new LocaleValue(obj["Caption"].ToString());
enumItem.EnumId = obj["Id"].ToString();
enumItem.Invalid = false;
enumItem.Value = obj["Value"].ToString();
enumList.Add(enumItem);
}
}
return enumList;
}
}
}
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,添加一个下拉列表字段,注册表单插件,保存元数据,开发完毕。
现在可以登录业务站点,打开采购订单编辑界面,验证一下使用自定义数据源的下拉列表控件的显示效果啦。
【参考资料】
【二开案例.元模型.下拉列表】https://vip.kingdee.com/article/134300640749955840
【二开案例.单据插件.下拉列表.动态填充下拉选项】https://vip.kingdee.com/article/84578415390870784
【二开案例.表单插件.下拉列表动态绑定枚举类型】https://vip.kingdee.com/article/137494654802820864
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.表单插件.下拉列表使用自定义数据源(SQL)
本文2024-09-23 04:20:38发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-164696.html