K3CloudDevTools【强类型DynamicObject代码生成器】
强类型DynamicObject代码生成器
DynamicObject是一个类似Dictionary的结构。实际使用过程中,需牢记Key,同时还需频繁进行类型转换,十分麻烦。 通过本工具,可以为表单创建一个强类型的DynamicObjectView代码,引用进工程后,可以把DynamicObject转换为该类。 利用VS的智能提示,可以方便的编写代码,不用在记字段名。
优点:
- 无需记住字段名称,VS可通过输入点号(.)自动带出,杜绝打错字的可能
- 基本不可能有人能完整记住这些字段名,导致每次用的时候都要去查找字段名,浪费时间
- 无需类型转换。鼠标放到字段上即可显示数据类型(典型如多语言字段,很多时候忘了去取中文)
- 能及时预防一些潜在Bug(重点点名物料,物料由于字段众多,不同字段存放于不同实体,读取时先读取实体再读取字段,很容易导致问题)
- 表单字段新增修改后,需重新生成(不重新生成不影响使用,只是新增字段需用原方法读取)
使用方法:
- 输入表单ID,点击生成。
- 将代码放到VS项目中,修改命名空间即可。默认类名为FormId+View
- 在具体代码处将DynamicObject转换为生成类:var dyo=(FormIdView)dynamicObject;
使用后效果对比:


BillView简介
有时候,我们通过后台代码新建表单时,如果直接操作数据包,表单插件、值更新事件等与视图有关的功能无法使用。
为了解决这种情况,我们可以构建一个BillView,利用此对象操作数据,比直接操作数据包有如下优势:
- 视图会自动触发插件,这样逻辑更加完整;
- 视图会自动利用单据元数据,填写字段默认值,不用担心字段值不符合逻辑;
- 字段改动,会触发实体服务规则;
为了便于使用,封装了个类,供大家使用。
BillViewService 代码
using Kingdee.BOS;
using Kingdee.BOS.Core;
using Kingdee.BOS.Core.Bill;
using Kingdee.BOS.Core.DynamicForm;
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Core.Metadata;
using Kingdee.BOS.Core.Metadata.FormElement;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.BOS.ServiceHelper;
using System;
namespace SuyanaProject.Services {
public class BillViewService {
private Context Context;
private IBillView billView;
public BillViewService(Context ctx,string formId) {
Context = ctx;
Create(formId);
}
public BillViewService(Context ctx, FormMetadata meta) {
Context = ctx;
Create(meta);
}
#region 属性
/// <summary>
/// 获取表单数据包
/// </summary>
public DynamicObject DataObject => billView.Model.DataObject;
/// <summary>
/// 获取表单Model
/// </summary>
public IBillModel Model => billView.Model;
/// <summary>
/// 获取表单视图
/// </summary>
public IBillView BillView => billView;
#endregion
#region 新建/打开表单方法
/// <summary>
/// 新建表单
/// </summary>
/// <returns></returns>
public BillViewService New() {
((IBillViewService)billView).LoadData();
fireOnLoad();
return this;
}
/// <summary>
/// 加载指定的单据进行修改
/// </summary>
/// <param name="billView"></param>
/// <param name="pkValue"></param>
/// <param name="billTypeId"></param>
/// <returns></returns>
public BillViewService Edit(object pkValue, string billTypeId = "") {
billView.OpenParameter.Status = OperationStatus.EDIT;
billView.OpenParameter.CreateFrom = CreateFrom.Default;
billView.OpenParameter.PkValue = pkValue;
billView.OpenParameter.DefaultBillTypeId = billTypeId;
((IDynamicFormViewService)billView).LoadData();
fireOnLoad();
return this;
}
#endregion
#region 值设置/获取方法
/// <summary>
/// 设置基础资料值(按代码)
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <param name="row"></param>
/// <returns></returns>
public BillViewService SetItemValueByNumber(string key, string value, int row = 0) {
IDynamicFormViewService dynamicFormView = billView as IDynamicFormViewService;
dynamicFormView.SetItemValueByNumber(key, value, row);
return this;
}
/// <summary>
/// 设置基础资料值(按内码)
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <param name="row"></param>
/// <returns></returns>
public BillViewService SetItemValueByID(string key, object value, int row = 0) {
IDynamicFormViewService dynamicFormView = billView as IDynamicFormViewService;
dynamicFormView.SetItemValueByID(key, value, row);
return this;
}
/// <summary>
/// 设置普通字段值
/// </summary>
/// <param name="key">唯一标识</param>
/// <param name="value">值</param>
/// <param name="row">行索引</param>
/// <returns></returns>
public BillViewService SetValue(string key, object value, int row = 0) {
IDynamicFormViewService dynamicFormView = billView as IDynamicFormViewService;
dynamicFormView.UpdateValue(key, row, value);
return this;
}
/// <summary>
/// 获取分录指定行的数据包
/// </summary>
/// <param name="key"></param>
/// <param name="row"></param>
/// <returns>
