二开案例.表单插件.赋值取值.单据类型字段
【应用场景】
单据类型字段赋值取值。
【案例演示】
采购订单,插件的方式对单据类型字段[单据类型]赋值取值。
【实现步骤】
<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>编写表单插件,...
点击下载文档
本文2024-09-23 04:01:14发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-162594.html
您需要登录后才可以发表评论, 登录登录 或者 注册
最新文档
热门文章