电脑桌面
添加蚂蚁七词文库到电脑桌面
安装后可以在桌面快捷访问

二开案例.表单插件.下拉列表使用自定义数据源(SQL)

来源:金蝶云社区作者:金蝶2024-09-234

二开案例.表单插件.下拉列表使用自定义数据源(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.FDOCUMENTSTAT

二开案例.表单插件.下拉列表使用自定义数据源(SQL)

【应用场景】使用自定义数据源,给下拉列表控件绑定下拉选项。【案例演示】采购订单,新增下拉列表字段,绑定下拉项为币别。【实现步骤】<1...
点击下载文档文档为doc格式

声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。

已经是第一篇
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息
QQ群
  • 答案:my7c点击这里加入QQ群
支持邮箱
微信
  • 微信