二开案例.列表插件.引出时隐藏列数据

栏目:云星空知识作者:金蝶来源:金蝶云社区发布:2024-09-23浏览:1

二开案例.列表插件.引出时隐藏列数据

【应用场景】

引出数据时,想把某些可见列的数据隐藏。


【案例演示】

采购订单列表,供应商列,界面可见,但按列表引出的Excel文件中不可见。


【实现步骤】

<1>编写列表插件,代码如下。

using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Core.Enums;
using Kingdee.BOS.Core.List.PlugIn;
using Kingdee.BOS.Util;
using System.ComponentModel;
using System.Data;
using System.Linq;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
    /// <summary>
    /// 【列表插件】引出时隐藏列数据
    /// </summary>
    [Description("【列表插件】引出时隐藏列数据"), HotUpdate]
    public class ExportHideDataListPlugIn : AbstractListPlugIn
    {
        public override void BeforeExportDataNew(BeforeExportDataNewArgs e)
        {
            base.BeforeExportDataNew(e);
            if (e.ExportOperate == BOSEnums.ExportOperateType.Export)
            {
                // 将供应商名称列的数据隐藏
                var columnName = "FSupplierId_FName";
                var dt = e.obj as DataTable;
                if (dt == null || dt.Rows.Count == 0 || !dt.Columns.Contains(columnName))
                {
                    return;
                }
                // 如果不知道列名,可通过此语句输出列名到界面
                //var columnNames = string.Join(",", dt.Columns.Cast<DataColumn>().Select(o => o.ColumnName));
                //this.View.ShowMessage(columnNames);
                foreach (DataRow row in dt.Rows)
                {
                    row[columnName] = "******";
                }
            }
        }
    }
}



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


<3>BOSIDE扩展采购订单,注册列表插件,保存元数据,开发完毕。


【功能验证】

<1>登录业务站点,打开采购订单列表,按列表引出数据,此时供应链列已显示成******。

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













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

二开案例.列表插件.引出时隐藏列数据

【应用场景】引出数据时,想把某些可见列的数据隐藏。【案例演示】采购订单列表,供应商列,界面可见,但按列表引出的Excel文件中不可见。...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息