二开案例.表单插件.动态创建按钮
【应用场景】
运行时,动态创建按钮。
【注意事项】
<1>此案例仅简单演示如何通过修改元数据的方式动态创建按钮,因为涉及到运行时修改元数据,具有一定的风险性(元数据缓存问题),非必要不推荐。
<2>界面有本地缓存,需清空本地缓存后,动态创建的元素才会显示。
【案例演示】
采购订单,新增界面,运行时动态创建按钮。
【实现步骤】
<1>编写表单插件,代码如下。
using Kingdee.BOS; using Kingdee.BOS.Core.DynamicForm.PlugIn; using Kingdee.BOS.Core.DynamicForm.PlugIn.Args; using Kingdee.BOS.Core.Metadata.ControlElement; using Kingdee.BOS.Util; using System.ComponentModel; namespace Jac.XkDemo.BOS.Business.PlugIn { /// <summary> /// 【表单插件】动态创建按钮 /// </summary> [Description("【表单插件】动态创建按钮"), HotUpdate] public class CreateButtonFormPlugIn : AbstractDynamicFormPlugIn { /// <summary> /// 按钮标识 /// </summary> const string ButtonKey = "F_Jac_Button"; public override void OnSetLayoutInfo(SetLayoutInfoArgs e) { base.OnSetLayoutInfo(e); var layoutInfo = this.View.LayoutInfo; var button = new ButtonAppearance(); button.Key = ButtonKey; if (layoutInfo.GetAppearance(button.Key) == null) { layoutInfo.Add(button); button.Container = "FHEADBASEPAGE"; button.Left = new LocaleValue("100", this.Context.UserLocale.LCID); button.Top = new LocaleValue("200", this.Context.UserLocale.LCID); button.Width = new LocaleValue("200", this.Context.UserLocale.LCID); button.Caption = new LocaleValue("动态按钮测试", this.Context.UserLocale.LCID); button.Id = "6b0ee640209f4277a813674d646eee3b"; e.BillLayoutInfo = e.LayoutInfo = layoutInfo; } } public override void ButtonClick(ButtonClickEventArgs e) { base.ButtonClick(e); if (e.Key.EqualsIgnoreCase(ButtonKey)) { this.View.ShowMessage("动态创建的按钮被点击啦!"); } } } } /* 按钮元数据 <LayoutInfos> <LayoutInfo action="edit" oid="bc952920-057d-4790-9c27-1134091eb298"> <Appearances> <ButtonAppearance ElementType="1002" ElementStyle="1"> <Container>FHEADBASEPAGE</Container> <ZOrderIndex>14</ZOrderIndex> <Tabindex>10</Tabindex> <Left>100</Left> <Top>200</Top> <Width>200</Width> <Caption>按钮</Caption> <Id>cf2bc43d32d24560815c265542850b5e</Id> <Key>F_Jac_Button</Key> </ButtonAppearance> </Appearances> </LayoutInfo> </LayoutInfos> */
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,注册表单插件,保存元数据,开发完毕。
【功能验证】
<1>登录业务站点,打开采购订单新增界面,会动态创建按钮,点击按钮,效果如下图。
---------------------------------------------------------------------------------------------------------
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.表单插件.动态创建按钮
【应用场景】运行时,动态创建按钮。【注意事项】<1>此案例仅简单演示如何通过修改元数据的方式动态创建按钮,因为涉及到运行时修改元数据...
点击下载文档
上一篇:二开案例.表单插件.动态创建菜单下一篇:系统运维.数据库.删除元数据
本文2024-09-23 03:58:43发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-162319.html
您需要登录后才可以发表评论, 登录登录 或者 注册
最新文档
热门文章