二开案例.列表插件.列表动态创建列

【应用场景】
列表界面上不依赖过滤方案指定的显示隐藏列配置,通过插件的方式动态的创建列并动态的给列赋值。
【案例演示】
采购订单列表,动态创建列并赋值。

【注意事项】
此解决方案仅支持版本PT-146869 [7.6.0.202103]及之后的版本。
【实现步骤】
<1>编写列表插件,代码如下。
using Kingdee.BOS;
using Kingdee.BOS.Core.List.PlugIn;
using Kingdee.BOS.Core.List.PlugIn.Args;
using Kingdee.BOS.Util;
using System;
using System.ComponentModel;
using System.Linq;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【列表插件】列表动态创建列
/// </summary>
[Description("【列表插件】列表动态创建列"), HotUpdate]
public class CreateDynamicListListPlugIn : AbstractListPlugIn
{
public override void CreateListHeader(CreateListHeaderEventArgs e)
{
base.CreateListHeader(e);
// 创建动态列1
var header = e.ListHeader.AddChild();// 将动态列放在列表的最后面
//var header = e.ListHeader.AddChild(0);// 将动态列放在列表的指定位置
header.Caption = new LocaleValue("动态列1");
header.Key = "FDynamicColumn1";
header.FieldName = "FDynamicColumn1";
header.ColType = SqlStorageType.Sqlnvarchar;
header.Width = 200;
header.Visible = true;
header.ColIndex = e.ListHeader.GetChilds().Max(o => o.ColIndex) + 1;// 注意:列的显示顺序不是ColIndex决定的,而是由该列在ListHeader的childs集合中的位置决定的。
// 创建动态列2
header = e.ListHeader.AddChild();// 将动态列放在列表的最后面
//header = e.ListHeader.AddChild(1);// 将动态列放在列表的指定位置
header.Key = "FDynamicColumn2";
header.FieldName = "FDynamicColumn2";
header.Caption = new LocaleValue("动态列2");
header.ColType = SqlStora二开案例.列表插件.列表动态创建列
【应用场景】列表界面上不依赖过滤方案指定的显示隐藏列配置,通过插件的方式动态的创建列并动态的给列赋值。【案例演示】采购订单列表,动...
点击下载文档文档为doc格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



