SharePoint 部件通过EditorPart自定义属性面板

简介: 需求:编写一个新闻展示的WebPart,要求可以分类,类别是从WebService中获取的字符串,要求可以在属性中勾选分类,显示该分类的信息,分类可能会增加。我要做的就是动态生成属性中的新闻类别,至于新闻展示就很简单了。

      需求:编写一个新闻展示的WebPart,要求可以分类,类别是从WebService中获取的字符串,要求可以在属性中勾选分类,显示该分类的信息,分类可能会增加。我要做的就是动态生成属性中的新闻类别,至于新闻展示就很简单了。

      首先,新建一个WebPart的类,然后添加引用,添加强命名,修改输出路径到bin下,然后加到网站中,引用进去,方便查看效果。

      然后,添加另一个类,EditorPart类,我们要做的,就是生成我们的控件,然后重写EditorPart的两个方法,来把类别输出到SharePoint属性面板中去。

protected override void   CreateChildControls()//初始化控件

public override bool   ApplyChanges()//保存设置

public override void   SyncChanges()//初始化EditorPart

        protected override void CreateChildControls()//初始化控件

        这个函数,是初始化控件的,编写方法,我们需要的控件,我这里只是需要CheckBox做勾选,还有一个Button做全选。

          protected override   void CreateChildControls()

          {

            string   type = GetTypeStr();

            string[]   type2 = type.Split(';');

            typecount = type2.Length;

            Table   table = new Table();

            table.CellPadding = 0;

            table.CellSpacing = 0;

            table.Style.Add(HtmlTextWriterStyle.Height, "190px");

            table.Style.Add(HtmlTextWriterStyle.Width, "200px");

            TableRow   row = new TableRow();

            TableCell   cell1 = new TableCell();

            TableCell   cell2 = new TableCell();

            for   (int i = 0; i < type2.Length; i++)

            {

                cb[i] = new CheckBox();

                cb[i].Text = type2[i];

                this.Controls.Add(cb[i]);

                row = new TableRow();

                cell1 = new TableCell();

                cell2 = new TableCell();

                cell1.Style.Add(HtmlTextWriterStyle.TextAlign, "left");

                cell1.Controls.Add(cb[i]);

                row.Cells.Add(cell1);

                table.Rows.Add(row);

            }

            btn.Click += new EventHandler(btn_Click);

            btn.Text = "全选";

            this.Controls.Add(btn);

            row = new   TableRow();

            cell1 = new   TableCell();

            cell2 = new   TableCell();

            cell1.Style.Add(HtmlTextWriterStyle.TextAlign, "left");

            cell1.Controls.Add(btn);

            row.Cells.Add(cell1);

            table.Rows.Add(row);

            this.Controls.Add(table);

          }

      public override bool ApplyChanges()//保存设置

      这个函数,是保存我们的变量的,但是需要把要保存的值回传到属性中去,才可以保存,也就是说EditorPart只有一个编辑功能,所以我在属性中声明了一个string类型的Test变量,用来保存。This也就是EditorPart中的参数,而生成的webpart对象,则是属性了。

          public override   bool ApplyChanges()

          {

            this.EnsureChildControls();

            MyTestWebPart   webpart = this.WebPartToEdit as MyTestWebPart;

            if   (webpart == null) return   false;

            webpart.Test = "";

            for   (int i = 0; i < this.typecount;   i++)

            {

                if   (this.cb[i].Checked == true && this.cb[i]   != null)

                {

                    webpart.Test += "1;";

                }

                else

                {

                    webpart.Test += "0;";

                } 

            }

            return   true;

            //throw   new NotImplementedException();

          }

      public override void SyncChanges()//初始化EditorPart

      这个和上面的函数,作用是相反的,也就是EditorPart读取到部件属性的函数,我读取到我的Test变量,然后通过这个变量,再初始化EditorPart的选项,使看起来EditorPart保存了设置一样。

          public override   void SyncChanges()

          {

            EnsureChildControls();

            MyTestWebPart   webpart = this.WebPartToEdit as MyTestWebPart;

            if   (webpart == null) return;

 

            string   GetTest = webpart.Test;

            string[]   GetTestGroup = GetTest.Split(';');

            for   (int i = 0; i < GetTestGroup.Length; i++)

            {

                if   (GetTestGroup[i] == "1")

                {

                    cb[i].Checked = true;

                }

            }

          }

 

         最后,在WebPart中获得编辑界面就可以了。这个就是在部件的属性面板中,初始化EditorPart的函数了,Title也就是属性的标题了。

          public override   EditorPartCollection CreateEditorParts()

          {

            EditorPartCollection   baseParts = base.CreateEditorParts();

            List<EditorPart> editorParts = new List<EditorPart>(1);

            EditorPart   part = new MyTestEditerPart();

            part.ID = this.ID + "_tagValueEditor";

            part.Title = "新闻类别";

            editorParts.Add(part);

            return   new EditorPartCollection(baseParts,   editorParts);

          }

        声明了一个Test的变量,用来保存EditorPart的值,然后Browsable设置成了false,不让用户看到。呵呵。

private string _Test = "";

          [Browsable(false),   FriendlyName("textbox类别"), Category("设置"), Description("请输入类别"), DefaultValue(""),   WebPartStorage(Storage.Shared)]

          public string   Test

          {

            get

            {

                return   _Test;

            }

            set

            {

                _Test = value;

            }

          }

效果:如下图所示,新闻类别,然后可以类别全选或者取消全选。

部件展示效果:[现在是勾选那个分类,页面上显示那个分类]

*************************************************************************************

作者:霖雨 出处:http://www.cnblogs.com/jianyus 本文版权归 霖雨和博客园共有,欢迎转载,但请注明出处。

目录
相关文章
|
10天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1216 5
|
9天前
|
机器学习/深度学习 人工智能 前端开发
通义DeepResearch全面开源!同步分享可落地的高阶Agent构建方法论
通义研究团队开源发布通义 DeepResearch —— 首个在性能上可与 OpenAI DeepResearch 相媲美、并在多项权威基准测试中取得领先表现的全开源 Web Agent。
1181 87
|
10天前
|
云栖大会
阿里云云栖大会2025年9月24日开启,免费申请大会门票,速度领取~
2025云栖大会将于9月24-26日举行,官网免费预约畅享票,审核后短信通知,持证件入场
1775 12
|
19天前
|
人工智能 运维 安全
|
2天前
|
资源调度
除了nrm-pm,还有哪些工具可以管理多个包管理器的源?
除了nrm-pm,还有哪些工具可以管理多个包管理器的源?
230 127
|
10天前
|
弹性计算 Kubernetes jenkins
如何在 ECS/EKS 集群中有效使用 Jenkins
本文探讨了如何将 Jenkins 与 AWS ECS 和 EKS 集群集成,以构建高效、灵活且具备自动扩缩容能力的 CI/CD 流水线,提升软件交付效率并优化资源成本。
362 0