二开案例.单据插件.禁止表格列拖动和缩放
【应用场景】表格中的列默认支持鼠标拖放更改列位置和列宽,有些用户希望禁用此特性。
【案例演示】采购订单,编辑界面,将明细信息单据体的所有列禁止拖动和缩放。
【实现步骤】
<1>编写单据插件,代码如下。
using Kingdee.BOS.Core.Bill.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.ControlModel;
using Kingdee.BOS.Core.Metadata.FieldElement;
using Kingdee.BOS.JSON;
using Kingdee.BOS.Util;
using System;
using System.ComponentModel;
using System.Linq;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【单据插件】禁止表格列拖动和缩放
/// </summary>
[Description("【单据插件】禁止表格列拖动和缩放"), HotUpdate]
public class EntryGridColumnsSetAllowMovingBillPlugIn : AbstractBillPlugIn
{
public override void AfterBindData(EventArgs e)
{
base.AfterBindData(e);
// 常规字段
var cols = this.View.BillBusinessInfo.GetEntity("FPOOrderEntry").Fields.Select(o => o.Key).ToList();
// 维度字段
var flexGroupFields = this.View.BillBusinessInfo.GetEntity("FPOOrderEntry").Fields.Where(o => o is RelatedFlexGroupField).Cast<RelatedFlexGroupField>().ToArray();
if (flexGroupFields.Length > 0)
{
foreach (var flexGroupField in flexGroupFields)
{
var flexFields = flexGroupField.RelateFlexBusinessInfo.GetFieldList();
foreach (var flexField in flexFields)
{
cols.Add(string.Format("$${0}__{1}", flexGroupField.Key, flexField.Key).ToUpper());
}
}
}
// 禁止表格列拖动和缩放
var colsJson = new JSONArray();
colsJson.Add("FSeq");
colsJson.AddRange(cols);
this.View.GetControl<EntryGrid>("FPOOrderEntry").InvokeControlMethod("SetAllowMovingAndResizing", colsJson, false);
}
}
}
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,注册表单插件,保存元数据,开发完毕。
现在可以登录业务站点,打开采购订单编辑界面,检验一下插件效果啦。
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.单据插件.禁止表格列拖动和缩放
本文2024-09-23 04:21:15发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-164758.html