二开案例.表单插件.下拉列表

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

二开案例.表单插件.下拉列表

【应用场景】

在界面上显示并使用下拉列表控件。



【案例演示】

采购订单,新增下拉列表字段,显示枚举值。



【实现步骤】

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

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.ComponentModel;

using System.Linq;


namespace Jac.XkDemo.BOS.Business.PlugIn

{

    /// <summary>

    /// 【表单插件】下拉列表

    /// </summary>

    [Description("【表单插件】下拉列表"), HotUpdate]

    public class ComboFieldFormPlugIn : AbstractDynamicFormPlugIn

    {

        public override void BarItemClick(BarItemClickEventArgs e)

        {

            base.BarItemClick(e);

            if (e.BarItemKey.Equals("tbShowItems", StringComparison.OrdinalIgnoreCase))

            {

                // 显示下拉列表的所有下拉项

                var comboField = this.View.BillBusinessInfo.GetField("F_Jac_Combo") as ComboField;

                if (comboField == null)

                {

                    return;

                }


                var enumItems = comboField.EnumObject["Items"] as DynamicObjectCollection;

                if (enumItems == null)

                {

                    return;

                }


                var msg = string.Join(",", enumItems.Select(o => string.Format("{0}:{1}", o["Caption"], o["Value"])));

                this.View.ShowMessage(msg);

            }


            if (e.BarItemKey.Equals("tbGetValue", StringComparison.OrdinalIgnoreCase))

            {

                // 获取下拉项

                var val = this.Model.GetValue("F_Jac_Combo").ToString();

                this.View.ShowMessage(val);

            }


            if (e.BarItemKey.Equals("tbSetValue", StringComparison.OrdinalIgnoreCase))

            {

                // 设置下拉项,将当前下拉列表的选中项设置为【已收货】

                this.Model.SetValue("F_Jac_Combo", "2");

                this.View.ShowMessage("下拉项已设置为【已收货】");

            }

        }

    }

}


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


<3>BOSIDE扩展采购订单,添加一个下拉列表字段,添加菜单子项,注册表单插件,保存元数据,开发完毕。



【功能验证】

现在可以登录业务站点,打开采购订单编辑界面,尝试使用一下下拉列表控件啦。

---------------------------------------------------------------------------------------------------------

【学习链接】

【二开案例.表单插件.设置下拉列表可编辑】https://vip.kingdee.com/article/121918117780843008

【二开案例.表单插件.下拉列表动态绑定枚举类型】https://vip.kingdee.com/article/137494654802820864

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

---------------------------------------------------------------------------------------------------------













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

二开案例.表单插件.下拉列表

【应用场景】在界面上显示并使用下拉列表控件。【案例演示】采购订单,新增下拉列表字段,显示枚举值。【实现步骤】<1>编写表单插件,代码...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息