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

二开案例.表单插件.多选辅助资料列表

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

二开案例.表单插件.多选辅助资料列表

【应用场景】

在单据上读取和显示多选辅助资料列表。



【案例演示】

采购订单,通过插件读取和显示多选辅助资料列表。

上传图片



【实现步骤】

<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.Collections.Generic;
using System.ComponentModel;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
    /// <summary>
    /// 【表单插件】多选辅助资料列表
    /// </summary>
    [Description("【表单插件】多选辅助资料列表"), HotUpdate]
    public class MulAssistantFieldFormPlugIn : AbstractDynamicFormPlugIn
    {
        /// <summary>
        /// 字段标识
        /// </summary>
        const string FieldKey = "F_Jac_MulAssistant";
        public override void BarItemClick(BarItemClickEventArgs e)
        {
            base.BarItemClick(e);
            var field = (MulAssistantField)this.View.BillBusinessInfo.GetField(FieldKey);
            var fieldAppearance = (MulAssistantFieldAppearance)this.View.LayoutInfo.GetAppearance(FieldKey);
            if (e.BarItemKey.EqualsIgnoreCase("test1"))
            {
                // 赋值
                /*
                 -- 查询辅助资料
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   c.FNAME = '国家';
                 */
                // 方式1:用内码赋值(1个或者多个,用逗号分隔)
                var ids = "46a524cf-5797-4e46-bd0a-7203fc426d9c,f98a3ac14f0b4397a332b2353f1fc66c"; // 中国,美国
                this.Model.SetValue(FieldKey, ids);
                // 方式2:用内码赋值(1个或者多个,用数组)
                //var ids2 = new object[] { "46a524cf-5797-4e46-bd0a-7203fc426d9c", "f98a3ac14f0b4397a332b2353f1fc66c", "5d03002c37f652" }; // 中国,美国,英国
                //this.Model.SetValue(FieldKey, ids2);
                // 方式3:用内码赋值(只能一个)
                //this.Model.SetItemValueByID(FieldKey, "46a524cf-5797-4e46-bd0a-7203fc426d9c", 0);
                // 方式4:用编码赋值(只能一个)
                //this.Model.SetItemValueByNumber(FieldKey, "China", 0);
                // 方式5:用数据包赋值(只能一个)
                //var loadParam = new QueryBuilderParemeter();
                //loadParam.FormId = "BOS_ASSISTANTDATA_SELECT";
                //loadParam.FilterClauseWihtKey = string.Format("FID='{0}' AND FNumber='{1}'",field.LookUpObjectID,"China");
                //var obj = BusinessDataServiceHelper.Load(Context, field.RefFormDynamicObjectType, loadParam);
                //this.Model.SetValue(FieldKey, obj[0]);
                return;
            }
            if (e.BarItemKey.EqualsIgnoreCase("test2"))
            {
                // 取值
                var objs = this.Model.GetValue(FieldKey) as DynamicObjectCollection;
                stri

二开案例.表单插件.多选辅助资料列表

【应用场景】在单据上读取和显示多选辅助资料列表。【案例演示】采购订单,通过插件读取和显示多选辅助资料列表。【实现步骤】<1>编写表单...
点击下载文档文档为doc格式

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

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