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

栏目:云星空知识作者:金蝶来源:金蝶云社区发布: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 EntrySetBackcolorBillPlugIn : 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 ? "" : "#cfe2f3";

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

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


            #region 设置某一行整行背景色


            if (e.BarItemKey == "tbSetRowBackColor")

            {

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

                {

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

                    grid.SetRowBackcolor(backColor, x);

                }

            }


            #endregion


            #region 批量设置某一行整行背景色


            if (e.BarItemKey == "tbSetRowBackColorBatch")

            {

                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.SetRowBackcolor(colors);

            }


            #endregion


            #region 设置物料名称字段的某一行的背景色


            if (e.BarItemKey == "tbSetBackColor")

            {

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

                {

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

                    grid.SetBackcolor("FMaterialName", backColor, x);

                }

            }


            #endregion



            #region 批量设置物料名称字段的某一行的背景色


            if (e.BarItemKey == "tbSetBackColorBatch")

            {

                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.SetCellsBackcolor("FMaterialName", colors);

            }


            #endregion

        }

    }

}


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


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


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


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

设置整行背景色效果:

设置某列背景色效果:















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


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

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