二开案例.表单插件.动态创建按钮

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

二开案例.表单插件.动态创建按钮

【应用场景】

运行时,动态创建按钮。



【注意事项】

<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>此案例仅简单演示如何通过修改元数据的方式动态创建按钮,因为涉及到运行时修改元数据...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息