二开案例.表单插件.赋值取值.单据类型字段

栏目:云星空知识作者:金蝶来源:金蝶云社区发布: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.ComponentModel;
using System.Linq;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
    /// <summary>
    /// 【表单插件】赋值取值.单据类型字段
    /// </summary>
    [Description("【表单插件】赋值取值.单据类型字段"), HotUpdate]
    public class BillTypeFieldSetValueFormPlugIn : AbstractDynamicFormPlugIn
    {
        /// <summary>
        /// 字段标识
        /// </summary>
        const string fieldKey = "FBillTypeID"; // 单据类型
        public override void BarItemClick(BarItemClickEventArgs e)
        {
            base.BarItemClick(e);
            var field = (BillTypeField)this.View.BillBusinessInfo.GetField(fieldKey);
            if (e.BarItemKey.Contains("test1"))
            {
                // 查询单据类型:SELECT a.FBILLTYPEID AS 单据类型内码,a.FNUMBER AS 单据类型编码,b.FNAME AS 单据类型名称,* FROM T_BAS_BILLTYPE a LEFT JOIN T_BAS_BILLTYPE_L b ON a.FBILLTYPEID=b.FBILLTYPEID AND b.FLOCALEID=2052 WHERE a.FBILLFORMID='PUR_PurchaseOrder'
                var billType = field.BillTypeInfo.First(o => o["Name"].ToString() == "标准委外订单");
                var billTypeId = billType[0].ToString();
                // 方式1:Model赋值(推荐使用)
                this.Model.SetValue(fieldKey, billTypeId);
                // 方式2:Model.DataObject赋值
                //this.Model.DataObject[field.PropertyName + "_Id"] = billTypeId;
                //this.Model.DataObject[field.PropertyName] = billType;
                //this.View.UpdateView(fieldKey);
                this.View.ShowMessage("单据类型字段已赋值");
                // TODO 【注意】此案例仅演示如何给单据类型字段赋值,单据类型切换后,整个界面要刷新重建,此案例不处理这部分逻辑。
            }
            if (e.BarItemKey.Contains("test2"))
            {
                // 方式1:Model取值(推荐使用)
                var value = (DynamicObject)this.Model.GetValue(fieldKey); // 用字段标识取值
                var msg = string.Format("单据类型内码:{0},单据类型名称:{1}", value["Id"], value["Name"]);
                // 方式2:Model.DataObject取值
                //var billTypeId = this.Model.DataObject[field.PropertyName + "_Id"].ToString();
                //var value = (DynamicObject)this.Model.DataObject[field.PropertyName]; // 用字段的属性名取值
                //var msg = string.Format("单据类型内码:{0},单据类型名称:{1}", value["Id"], value["Name"]);
                this.View.ShowMessage(msg);
            }
        }
    }
}


数据包中单据类型字段的数据结构如下图所示。


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


<3>BOSIDE扩展采购订单,菜单集合新增两个菜单项,注册表单插件,保存元数据,开发完毕。



【功能验证】

<1>登录业务站点,打开采购订单新增界面,赋值取值操作如下图。

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













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


二开案例.表单插件.赋值取值.单据类型字段

【应用场景】单据类型字段赋值取值。【案例演示】采购订单,插件的方式对单据类型字段[单据类型]赋值取值。【实现步骤】<1>编写表单插件,...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息