二开案例.表格控件.前景色

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

二开案例.表格控件.前景色

【应用场景】设置表格控件的数据行的前景色。

【案例演示】采购订单的明细信息,设置单双行显示不同的颜色。

【实现步骤】

<1>编写单据插件,实现设置指定单元格前景色的功能,代码如下。

using Kingdee.BOS.Core.Bill.PlugIn;

using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;

using Kingdee.BOS.Core.DynamicForm.PlugIn.ControlModel;

using Kingdee.BOS.Util;

using System.Collections.Generic;

using System.ComponentModel;


namespace Jac.XkDemo.BOS.Business.PlugIn

{

    /// <summary>

    /// 【单据插件】设置表格前景色

    /// </summary>

    [Description("【单据插件】设置表格前景色"), HotUpdate]

    public class GridSetForeColorBillPlugIn : AbstractBillPlugIn

    {

        private bool reset = true;


        public override void EntryBarItemClick(BarItemClickEventArgs e)

        {

            base.EntryBarItemClick(e);

            reset = !reset;

            var rowCount = this.View.Model.GetEntryRowCount("FPOOrderEntry");

            if (rowCount <= 0)

            {

                return;

            }

            var backColor0 = reset ? "" : "#FF0000";

            var backColor1 = reset ? "" : "#FF00FF";

            var grid = this.View.GetControl<EntryGrid>("FPOOrderEntry");


            #region 设置指定字段的某一行的前景色


            if (e.BarItemKey == "tbSetForeColor")

            {

                for (var x = 0; x < rowCount; ++x)

                {

                    var backColor = x % 2 == 0 ? backColor0 : backColor1;

                    grid.SetForecolor("FMaterialId", backColor, x);

                }

            }


            #endregion


            #region 批量设置指定字段的某一行的背景色


            if (e.BarItemKey == "tbSetForeColorBatch")

            {

                var colors = new List<KeyValuePair<int, string>>();

                for (var x = 0; x < rowCount; ++x)

                {

                    var backColor = x % 2 == 0 ? backColor0 : backColor1;

                    colors.Add(new KeyValuePair<int, string>(x, backColor));

                }

                grid.SetCellsForecolor("FMaterialName", colors);

            }


            #endregion

        }

    }

}


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


<3>BOSIDE扩展采购订单,选中明细信息单据体,新增2个菜单,如下图所示。


<4>注册表单插件,保存元数据,开发完毕。


现在可以登录业务站点,打开采购订单,检验一下插件效果啦。















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


二开案例.表格控件.前景色

【应用场景】设置表格控件的数据行的前景色。【案例演示】采购订单的明细信息,设置单双行显示不同的颜色。【实现步骤】<1>编写单据插件,...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息