二开案例.表单插件.下拉列表动态绑定枚举类型

栏目:云星空知识作者:金蝶来源:金蝶云社区发布:2024-09-23浏览:1

二开案例.表单插件.下拉列表动态绑定枚举类型

【应用场景】使用已存在的枚举类型,动态绑定到下拉列表控件。

【案例演示】采购订单,新增下拉列表字段,动态设置下拉列表控件的下拉项为枚举类型【发货状态】的枚举值集合。

【实现步骤】

<1>编写表单插件,代码如下。

using Kingdee.BOS;

using Kingdee.BOS.Core.DynamicForm.PlugIn;

using Kingdee.BOS.Core.DynamicForm.PlugIn.ControlModel;

using Kingdee.BOS.Core.Metadata;

using Kingdee.BOS.Orm.DataEntity;

using Kingdee.BOS.ServiceHelper;

using Kingdee.BOS.Util;

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Linq;


namespace Jac.XkDemo.BOS.Business.PlugIn

{

    /// <summary>

    /// 【表单插件】下拉列表动态绑定枚举类型

    /// </summary>

    [Description("【表单插件】下拉列表动态绑定枚举类型"), HotUpdate]

    public class FillComboFieldByEnumObjectFormPlugIn : 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 objs = BusinessDataServiceHelper.LoadFromCache(ctx, new object[] { "0113bd8e-03b1-4c47-8fb4-9ed5b9074680" }, EnumObject.EnumObjectType);

            var enumList = new List<EnumItem>();

            if (objs != null && objs.Length > 0)

            {

                var enumItems = (DynamicObjectCollection)objs[0]["Items"];

                enumList.AddRange(enumItems.Select(o => (EnumItem)o));

            }


            return enumList;

        }

    }

}




/*

-- 查询枚举类型

SELECT a.FID AS 枚举类型内码,b.FNAME AS 枚举类型名称,* FROM T_META_FORMENUM a

LEFT JOIN T_META_FORMENUM_L b ON a.FID=b.FID AND b.FLOCALEID=2052

WHERE b.FNAME=N'发货状态'


-- 查询某个枚举类型下的所有枚举项

SELECT a.FENUMID AS 枚举内码,b.FCAPTION AS 枚举名称,a.FVALUE AS 枚举值,* FROM T_META_FORMENUMITEM a

LEFT JOIN T_META_FORMENUMITEM_L b ON a.FENUMID=b.FENUMID AND b.FLOCALEID=2052

WHERE a.FID='0113bd8e-03b1-4c47-8fb4-9ed5b9074680'

ORDER BY a.FSEQ

*/


<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。


<3>BOSIDE扩展采购订单,添加一个下拉列表字段(不需要绑定枚举类型),注册表单插件,保存元数据,开发完毕。



现在可以登录业务站点,打开采购订单编辑界面,验证一下使用枚举类型的枚举项集合做数据源的下拉列表控件的显示效果啦。




【参考资料】

【二开案例.元模型.下拉列表】https://vip.kingdee.com/article/134300640749955840

【二开案例.单据插件.下拉列表.动态填充下拉选项】https://vip.kingdee.com/article/84578415390870784

【二开案例.表单插件.下拉列表使用自定义数据源(SQL)】https://vip.kingdee.com/article/137250328441093888















【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696

二开案例.表单插件.下拉列表动态绑定枚举类型

【应用场景】使用已存在的枚举类型,动态绑定到下拉列表控件。【案例演示】采购订单,新增下拉列表字段,动态设置下拉列表控件的下拉项为枚...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息